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ممدمهك 

الحمد لله كما يحب رينا ويرضى . والصلاة والسلام على عبده المجتبى » سيدنا محمد ج .ورضي الله عن 
صحابته الأطهار وزوجاته امهات المؤمنين وبعد.. 

فهذا الكتاب الذي بين يديك هو عمل منقوص بلاشك من جهتين أن الانسان لا يصل للكمال بطبيعة حاله › 
وأنه ليس العمل النهائي الذي أنشده . تعجلت في طرحه على الرغم من توقعي أنه لم پبلغ ثلث ما أعد له 
> ولكن حتي يتواصل مع جمهور المهتمين بإثراء المحتوى العربي من كتب البرمجة لكي أحسن هذا العمل 
وغيره من الأعمال المستقبلية إن شاء الله . الكتاب قريب من 100 صفحة بدأت فيه بالمعلومات الضرورية 
عن عالم قواعد البيانات بشكل موجز واکاديمي » يسهل على أي مبتدئ فهمه وان تعثر فقد ترکت مفاتيح 

لكي يقوم بالبحث بها بنفسه لأن عالم البرمجة لاتتوقع أن يطعمك كل انسان كافة احتياجاتك للعلم » كما 

وأن هذا الكتاب ليس لتعليمك لغة ٥#‏ يمكنك ايجاد عشرات المراجع للبداية فى تعلم هذه اللغة الرائعة › 
وسافترض ان ل لديك الحد ا بها. 


محانية لکن بن بنسخة اقل من حيث الامكانيات وهي النسخة ss٥٣م>Ex‏ ۽ ا فالاکوا ا فی 


SQL Server ةزخةwill‎  Jiحو‎ 2008 J| 2005 ابتداعءا من‎ SQL Server aخسiن الکتاب تم تطة‎ 


2 2008 بكافة اصداراتهم بدون أي مشاكل . وستلاحظ هذا من خلال الصور الملتقطة للعمل على اهSQ‏ 
Sere‏ بدون التنويه على تغير النسخة لأنها ستعمل معك بكفاءة مع أية نسخة.ولو صادفك أية مشكلة 
يمكنك التواصل معى لمساعدتك بقدر الإمكان . ثم يستمر الكتاب باستعراض مبادئ العمل فى بيئة اهS؟S‏ 

ere‏ والتعرف على كيفية التعامل مع البيانات من ادخال وحذف وتعدیل » ثم يات دور التعرف على 
Procedures‏ edاSt0من‏ كيفية انشاءها والعمل عليها . وتضمينها داخل أكواد #© ويالمناسبة أيضا الأكواد 
تعمل على بيئة الدوت نت 2.0 إلى 4.0 بلا أي مشاكل أيضاً راعيت هذا اثناء الإعداد للكتاب .ثم نتعرف 
على ]۷× وكيفية تعاملها مع البيانات وفهم خصائصها . تم نختم بالتعامل مع l|لعlılnۈت Transactions‏ 
وكيفية كتابة كود ۸50.٤‏ لهذه العمليات. 

ما سوف أمضي فيه إن شاء الله في تطوير الكتاب واصدار مزيد من الفصول سوف يتعمق في 

A 0.N٤1‏ والتعرف على مبادئ كتابة برامج فواعد بيانات لتطبيقات الويندوز وكذلك الويب. 


أرجوا أن تستمتعوا بالكتاب والرجوع إلى حال مصادفتكم أيه مشاكل أثناء عملكم عليه. 

في الختام أشكر كل من شجعني وثابر معي وسيثابر لأن العمل لم ينتهي بعد .وأخص بالشكر زوجتي 
وأخوتي وأصدقائى فى العمل على حثهم لإنهاء هذا الكتاب جزاهم الله خيرً. 

وفقنا الله وایاکم لما يحبه ویرضاه. 


حسام كمال محمد 


hosam @ live.co.uk 
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نبذه عن إلموؤل 


حاصل على بكالوريوس الحاسبات والمعلومات ۲٠۰۸‏ - جامعة المنصورة - 
وأعمل مطور شيربوينت بشركة NWO)‏ امpروE‏ .لدي الخبرة وإجادة 

العمل بکJ C#,ASP.NET,SQL Server,SharePoint ,InfoPath, XML ja‏ 
يمكنك متابعة مدونتى التقنية فيما يخص الشيربوينت وكذلك بيئة الدوت نت 
والتواصل معي على الرابط التالى: 


http://sharepointhero.wordpress.com/ 
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سے 

رقم الصفحة 
قبل الشروع في العمل O ay‏ 
تتبيٽ 2008 O MS SQL Server‏ 
متطلبات ما قبل التثبيت RR‏ 
sS UTE‏ 
مدخل إلى قواعد البيانات العاںئقıة O Relational Databases‏ 
فى هذا الفصل سوف تتعلم الأتى: E N oo‏ 
ما هی قواعد البيانات ؟ O‏ 
ما هو نظام إدارة قgاعد‏ llبlyنlٽ Data Base Management System ( DBMS)‏ ؟ E a‏ 
م| ھg‏ — Relational DBMS‏ ؟ E‏ 
لماذا أستخدم قواعد البيانات ؟ O‏ 
فوائد استخدام نظم إدارة قواعد البيانات العلائقية R58 MS‏ ؟ E E‏ 
الفرق بين ۸588S‏ لأنظمة سطح المكتب و الخوادم وإم۷إمS oo‏ 1 
دورة حياة نظم قواعد البيانات O o DB Life Cycle‏ 
إيجاد العلاقات بين البيانات O‏ 
فهم المفاتیح ر۸ N ETF E TOE FE IEEE‏ 
فهم تمم llبlنlIٽ O RR o Data Integrity‏ 
فھم مڊlدئ r ooo Normalizatioİ‏ 
gw‏ ئ lڏNormalization O‏ 
خاتمة الفصل E o‏ 
الفصل الثانى o‏ 
کتابة استعلامات قواعد llبيlنlٽ A O RR Database Queries‏ 
فى هذا الفصل ستتعلم RR r oo‏ 
المقارنة بين O oy QBE and SQL‏ 
البدء مع كتابة الاستعلامات وعزامQu N‏ 
جرب هذه: تنفیذ استعلام بسیط ooo‏ 
اجراءات وأوامر التعامل مع الجداول A‏ 
جlnة O GROUP BY‏ 
المعامل o P1۷01‏ 
O ROW_NUMBER lı‏ 
جãln E PARTITION BY‏ 
تو افق الکو E Pattern Matching Û‏ 
دو O Aggregate Functions gaجتll JI‏ 
دوال الوقت تريخ N a DATETIME Functions‏ 
فم O JOINS‏ 
E Inner Joins‏ 
O I OD O O O o Outer Joins‏ 
O Other Joins‏ 
خاتمة الفصل aaay‏ 
الفصل الثالث N‏ 
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E Manipulating Database Data ٽlنlيبll التعامل مع بيانات قاعدة‎ 

r ooo سنتعلم فى هذا الفصل التالي:‎ 
A إسترجاع البيانات‎ 
E WHERE استخدام الضشرطڊط‎ 
O oy WHERE طرûll‎ ga Comparison Operators ةiرlقمئll‎ Jماوع استخدام‎ 
RR Combining Predicates طgرڙشll دمج‎ 
O r ooo Sorting Data ٽlنlبll‎ jرف‎ 
N a SELECT INTO ةlمجلا إستخدام‎ 
O Table Structure wil SELECT INTO مlڌختul‎ 
A gga Inserting Data ٽlنlيبll‎ Jاخدإ‎ 
ys Updating Data ٽlنlيبll تحديث‎ 
E Deleting Data ٽlنlڊll حذز‎ 
E خاتمة الفصل‎ 
O o الفصل الرابع‎ 
EO Using Stored Procedures ةijخhلا استخدام الإجراءات‎ 

E Stored Procedures يهاlم‎ 
E oy : في هذا الفصل سنتعلم‎ 
E aa Stored Procedures sll yı 
o SQL Serverga Stored Procedure ”ذİE‎ Jaalا فة‎ 
E يحوي معاملات‎ Stored Procedure إنشاء‎ 
O Stored Procedure: آ‎ Jıدعت‎ 
aa SP Definitions ضl استعر‎ 
o إعادة تسمية ۲؟‎ 
0 C# كيفية استعمال 8۲ داخل أكواد‎ 
N o Deleting Stored Procedure ءl حذزف !}جر‎ 
RR oa خاتمة الفصل‎ 
E oy الفصل الخامس‎ 
E OD O O O GD a ×1 استخدام‎ 

a Rg في هذا الفصل سنتعلم الأتي:‎ 
O XML تعریف‎ 
O لماذا 1× ؟‎ 
O ×M1 مزايا تخزين البيانات على صورة‎ 
E ×M1 تعرف على وثائق‎ 
a XML Declaration ذم‎ 
E ×“ تحويل البيانات العلائقية إلى‎ 
E O o :FOR XML RAW gl 
O a FOR XML AUTO İث‎ 
O O ×ML كيفية تخزين واسترجاع یارس uءمل 1× باستخدام أنواع بیانات‎ 
LA o خاتمة الفصل‎ 
N Ty الفصل السادس‎ 
o E Transactions تٽlيlمعll‎ 

E ؟‎ Transactions ماه„ آ—‎ 
E Ly ؟‎ Transactions —| Jمعتسن متى‎ 
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O O o ۸٥1( فهم الخصائص‎ 
E Transactions |آ—‎ ميaصت‎ 
N Transaction آ—‎ ٽٺلlح‎ 
N SS DSS SESS E NAGE AD i Transactions Î (Boundaries) gدح‎ juızت‎ 
O ؟Transaction‎ — ماهي جمل ۲-501 المسموح بها في‎ 
E SQL العمليات المحلية (sم0ناھsمTra إLoca) في‎ 
O SQL ف„‎ (Distributed Transactions) ع‎ jgnll العمليات‎ 
E دليلك لكتابة أكواد عمليات فعالة‎ 
| كيفية برمجة العمليات‎ 
E O O 1-؟SQا1 برمجة العمليات باستخدام‎ 
E Dy ۸D90.N ۴۲ كتابة أكواد للعملیات باستخدام‎ 
O O خاتمة الفصل‎ 
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قبل الشروع في العمل 


MS SQL Server 2008 تبيٽت‎ 
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متطلبات ما قبل التثبيت 

لابد من توفر الحد الأدني من الامكانيات التالية لكي تستطيع تثبيت 2008 إء۷إء؟ NS SQ]‏ إلى جهازك » ونعني بالجهاز هنا 
الكمبيوتر الشخصي أو حتی جهاز خادم: 

E DT OY‏ على النسخة الخفيفة ووعإم Ex‏ آم النسخة الكاملة › والفارق بينهما كبير اختصاراً فهو يكمن في 
دعم عدد من الاجراءات والعمليات وكذا مساحة قاعدة البيانات وعدد دعم المستخدمين المتصلين في المرة الواحدة. 

سنتحدث عن الأحد الأدني وهو النسخة الخفيفة وفيما عدا ذلك قم بالبحث عن توافق النسخة الكاملة مع امكانياتك وكذا طريقة 
التثبيت الى لن تختلف عن النسخة Express‏ الى نحن بصدد تثبيتها بمكنك اذا استشعرت الملل من متايعة الخطوات مشاهدة 
هذا الفيديو على يوتيوب (لست مسئولاً عن تغير الرابط في أي وقت): 
http://www.youtube.com/watch?v=CXJP4D503Tk‏ 


أو تابع الشرح معي... 
اولا : 
لابد من توافر أحد هذه الأنظمة على جهازك : 
Windows Server 2003 Service Pack 2, Windows Server 2008, Windows Vista, Windows Vı1sta Service Pack 1,‏ 
Windows XP Service Pack 2, Windows XP Service Pack 3 ,WIindowSs 7. 1‏ 
ثانبا ٠‏ 
الحد الأدنى من الذاكرة المتطلبة ٠٠٠١‏ لكن بفضل ١‏ جيجا على الأقل وأعتقد أن اغلب الأجهزة تحوي هذا الطلب ٠‏ كذلك توفر 
مساحة على القرص الصلب لا تقل عن ۲ جیجا وکلما زادت كلما كان أفضل ومعالج قوته لا تقل عن آ کا هرر ءا ۲۲ 
بت او 1 بت › ويفضل ان نگ ن من طراز انتل × 2 بت لان النسخة وومإم×ع لا تعمل مع معالجات IA64‏ القديمة. 
للحصول على نسخة وومإم×ع يُمكنك متابعة الرابط التالي (مع التنويه أنه عرضة للتغير): 
http://www.mi1crosoft.com/en-us/download/detalls.aspx ?1d4=1695‏ 
وستلاحظ وجود نسختین احدھما تسمی ع ×ع. 8Q1 8×X۶۸_×64_E N1‏ وهي لمعالجات ٠٤‏ بت » والأخرى تسمى 
SQL EXPR_x86_ENU.exe‏ وهی لمعالجات ۳۲۲ بت التي تتوفر في اغلب الأجهزة الشخصية » قم بتحميل ما يناسبك من كلتا 
النسختين » وقبل الشروع في التثبيت تأكد من توفر بيئة الدوت نت 1مء 3.5 ويمكنك البحث عنها او تنزيل الاصدار الرابع فهذا 
أفضل (بديهي عملك على فيجول ستوديو ۲١٠١‏ يتضمن تثبيت بيئة الدوت نت) وكذلك ينبغي توفر 4.5 .Windows Installer‏ 
بعد التحميل قم بالتثبيت وسيظهر لك هذه الاختيارات .. 
قم باختيار الخيار الأوسط كما بالشكل وهو احد الخيارات في عملية التركيب › والتي يسمح لنا بمشاهده أكبر عدد ممكن من 
الخدمات٠‏ 


SQL Server 20038 Express Setup Package 


Downloads and intalls prerequkite software, and then ingtalls an جر‎ SOL Sarver 2002 
instance of SQL Server 2008 Express, ٩ e 


select the language for your instance of SQL Server 2002: 
| E ûlishi 3 


Select the edition of SOL Server 2008 to install: 
0 SOL: Server 2005 اتا‎ with a 


nma RHIAN N 1M N1 I 11 E 1 A U 1 1f, 


CC S01 5 SafryEr ; 3008 E 


The folliiirg software prerequisites will ba installed: 


a Windoes Iretaller 4.5 
a Windoees Fowershell 1.0 


er eel 
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اختر Install‏ تم ی اأنافذة التالية ادا كانت احدي هده المتطلبات غير موجودة 


ê Microsoft SOL Server 2008 Express Download 


SQL Server 2008 Express Setup Package 


Downlsads and installs preraquisite software, and then installs an 


The required components are belng downloaded and installed. 


7 Windows Installer A45 
Windows Porershell 1.0 
SH Server 2E Express with Aîvancged Services 


Current task: 
Downloading Yindowss Installer 4.5 
Cverall progress: 


کے 
اا | Wê Microsoft SQL Server 2008 Express Download E 3 E‏ 


SQL Server 2003 Express Setup Package 


Downloads and installs prerequisite software, and then installs an ر‎ ¢٩ j Server 2008 
instance of SQL Server 2008 Express. چ‎ 


The required components are being downloaded and installed. 


Windows Installer 4.5 
:# SQL Server 2008 Express with Advanced Services id 


Current task: 
Downlsading SOL Server 2008 Express with Advanced Services 
Overall progress: 


ثم يتبع بالتالي وهي قواعد التثبيت : 
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ا× اطا 


Î SQL Server 2008 Setup 


Setup Support Rules 


Setup Support Rilss identfy problems that might occur whan you install SQL Server Sakup support files. Failures mst be corretkted 


| peration completed, Fassed: 6. Failed O. Warning O. Skpped 0. 


| Hide details << | Earn 


Wie detailed report 


| Rule 
Rimî oper abing system version 
2 SEtip adimiriskrakêr 
ا‎ (Restart cornpibef 


windows Management Instrumentation (YM) service‏ ت 
Consistency valdator for SOL Server regisbry keys‏ ت 
Long path names to files an SAL Server instalation media‏ ت 


before Setup can continuë. 


Setup Support Rules 


بعد الضغط على )»م يتم الذهاب إلى شاشة رقم المنتج حيث يتم وضع الرقم للمنتج ..لكن هنا لا نحتاج أي رقم لأن البرنامج 


عبارة نسخة Express‏ أنظر الشاكل الاي 


ا× ا٥ا‏ 


Specify ã free edition of SOL Server or provide a SOL Server product key to validate this instance of SQL Seryer 
A0, Enter the 25-chararcter key fram Ehe Microsoft certificate of authenticity or product packaging. I Yol 
specify Enterprise Evaluation, he instance wll be actiyated with a 150-day expiratlan, Ta uparade from one 
adilon Eo another editor, ran the Edilion LIpgrade Wizard, 


a SEY a FEE EUT 


Express ih Ar aNcET SEFEES ۳ 


{ Enber Hie pf IU FEY 


o ۸ as ۸ aaa ۸A o ۹۸ --- 


wer 2008 Setup 


Product Key 


Specify the edition of SOL Serwer 2008 Eo install. 


Product Key 
LiEsêrıê Terms 
Setup Support Files 


بعد هذه الخطوة يتم الذهاب غلى شاشة قبول الترخیص بیتم إختاير الخیار وصإ٥‏ عم ء1 eطt Accept‏ 1ءبعد ذلك يتم الضغط 


على )× كما في الشكل التالي: 
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Ê 5Q1 Server 2008 Setup _ oy ع اا‎ 
License Terms 


To install SOL Server 200E, you must accept the Microsoft Software License Terms. 


Product Key 

Jena Fame MICROSOFT SOFTWARE LICENSE TERMS 

e i MICROSOFT SQL SERVER 2008 EXPRESS WITH TOOLS EDITION 
MICROSOFT SQL SERVER 2008 EXPRESS WITH ADYANCED SERVICES 
EDITION 


These license terms are an agreement between Microsoft Corporation (ar based on where you 
liye, one of its affiliates) and you, Please read tem. They apply to the software named 
above, which includes he media on which you receiwed it, if any. The terms also apply to any 
icra 


ss Înternet-based services, and 


e Spparlt seEr¥lEES 


ar Hai aah ıı mlre alam Fae xene as Haar Fae TF an Haan kar e xama =| 


E 
kopy Print 


| Ê SQL Server 2008 Setup E TT طا‎ × 
Setup Support Files 


Tlrk Irstall to install Setup Support files, Ta install or updake SQL Server 2008, these flas are required, 


Product Key The foloing components are reqUlred for SL Server SEkup: 
Setup Support Files Setup Support Files : : 


بعد ذلك يتم عمل فحص لقوانين التنصيب مرة أخرى كما في الشكل التالي: 
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| Ê 5L Server 2008 Setup : 238 ادا‎ 
Setup Support Files 


lkk Install fo install Sebup Support Files, To Install or updake SQL Server 2008, these files are required, 


Prodict Key 
License Terms 
Setup Support Files J Setup Support Files | In Progress 


Performing Windows Installer ãftionš. 


| ست[ س 
ر 


| Ê SQL Server 2003 Setup î 5 8 آ× اطا‎ 
Feature Selection 


Select the Express with Advanced Services Features to instal, For clustered installations, only Database Engine Services and Analysis 
Services can be clustered. 


Setup Support Rules Eeabures: Desrriptian: 


Feature Selection ÎristaNICE Fea E5 Server Feakuyres are instance-aware ard 
instance Sonfigur abori Gakabase Engine Services haye their own registry hes, They 

BE Saa REG E SQL Server Replication spport mulbiple instances on a compiler, 
ET : Shared Feabıres 

Management Tools - Easle‏ شڪ اا ا 

Database Engine Configuration [¥] 5L Cent Connectivity SOK 

Errûr and sage Reporting Redistributable Features 

Installation Rules 

Ready ta Install 

installation Progress 


select ll | Unselect Al | 


Shared feature directory: 2: Pragram Fles{MicrosofE SL Server) 9 


۸ * Back ext x» ١ Cancel | Help ٤ 


بعد الضغط على ٥×)‏ نذهب إلى شاشة اعدادات ال معمه)یم! »حيث يمكن أن نختار إسم لل ceہ‏ )یہ . 
كما في الشكل التالي: 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


î S5qL Server 2008 Setup 


Instance Configuration 


specify the famêë and imêtanıze ID For the SQL Server instaficê. 


Sêlup Support Rules (Default instance 


Feature Selection f Named stance:  oexoress 
Instance Configur ation 

Disk Space Requirements 

Server Configuration Instance ID: BQLEXpESS | 
a E EEE IrsEarce rak directory: [CiProgram FleslMicrosoft SQ Serve ا‎ 
Error and lsagê Reporting 

Irstallaklan Rules ڪصجصصحج ج ڪڪ کے‎ 
Ready ta Install 3L Server directory: ZH Program Files\Microsoft SL Server {MSSQL10.SQLExpress 

Installation Progress 

kets Installed instances: 


| Features 


< Back | ext > | Carel | Help ٤ 
2 


بعل الضغط قل Next‏ نذهب إلى شاشة تخذنك ال Service Accounts‏ قم بادخال اسم الحساب الأدمن ( اسم المستخدم خاصتت 
CE a,‏ 


f SQL Server 2008 Setup : e ادا‎ × 


Server Configuration 


Specify Ehe canfiauiralar. 
Setup Support Rules Service Accounts | Collation | 
Product Key 
Ea TE Hicrosoft recommends that you Use a separate account for each SQL Seryer service, 
Feature Selection Serwlce | Password | Skartup Type 1 
Instance Configuration SOL Server Database Engine NT AUTHORITSYSTEM 
Lisk Space Requirements 
Server Configuration 
Database Engine Configuration 
Error amd Lage Reporting 
Installation Riles These serves wall be configured E possible ta use a low privilege account, On some 
Ready to Install older Windows versions the user will reed to specify a lom privilege account, For more information, click 
Installation Progress E 
Complete | Password | Startup Type 


sever eros NTAVTHRRIMYSTEN 
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ا× اا 
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Ê 5QL Server 2008 Setup 


Database Engine Configuration 


Sperify Database Engine authentication securkty made, admiristratars and data drectories. 


Account Provisioning | Data Directories | FLESTREAM | 


Specify the authentication mode and administrators for the Gatabase Engine, 

Authentication iade 

f Windows authentication mode 

£" Mixed Made {SQL Server authentication and Windows authentication) 

Built-in SOL Server system administrator account 

ڪڪ کڪ Enter password:‏ 
ص ج ڪڪ ڪڪ confirm password:‏ 


Spey SQL Server administrators 


Administrator) 


| 3L Server adminiskrakors 
‘have unrestricted access Eo 
the Database Engine. 


Add Current User | Add... | Remove | 


Sekup Support Rules 
Product Key 

Lense Terms 

Featurs Selection 
Instance Configuration 
Dk Space Requirements 
server Configuration 
Database Engine Configuration 
Error amd sage ReporEing 
Installation Rules 

Ready to Install 
Irstallatiar Progress 


<k | ez | cancel | Help 


بعد الضغط گل Next‏ نذهب إلى شاشة تقارير الإستخدام والأخطاء Error and Using Reporting‏ فنقو م باختار الخيار ات كلها 
لأن ذلك يساهم في دعم المنتج المستمر لتلافي أية مشاكل مستقبلية › ثم بعد ذلك عند الضغط على )× نرجع إلى شاشة 


قواعد التثبيت كما في الشكل التالي: 


× إا 


Ê SQL Server 2008 Setup 


Installation Rules 


Sebup s5 running rules to determine IF the Iinstallatlian process will ba blocked, For more irforrmatlon, click Help. 


peration completed, Fassel: 9. Faled O, Warring O. SkKHpped 2. 


Same ar thikecturs installation‏ | ي 

(Cross language installation‏ ي 

Extsting utered ar cluster-prepared insktanğe‏ | ي 

(Reporting Services Catalog Database Fle Existence | Not applicable‏ ي 
ESE‏ 

Eel Server 2005 Express tools | Passed‏ ي 


Reportirıg Szervices Catalog Temporary Database File Exîştenge‏ | ا 


Operating system supported For edition Passed‏ | ا 
FûT32 File System |‏ @ 


sa Server 2000 Analysis Services (64-bit) install action‏ ي 
ا 


Instance namê‏ ا 


(Previous rêlaasês of Microsoft Visual Studio 2003‏ ي 


SeFup Support Eles 
Produrt Key 

LKênsê Têrmis 

Feature Selection 
Instance Carıflguraktlan 
Cs Space Requirements 
Server Configuration 
Databasa Engine Corfigur aon 
Errar ard sage Reporting 
Installation Rules 
Ready to Install 
Installation Progress 
Camplekte 
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عند الضغط على )×6 نذهب إلى شاشة الإستعداد للتثبيت كما في الشكل التالي: 


| FESAL Server 2008 Setup = a ادا‎ × 
| Reacdly to Install 


verify the SQL Server 2008 fFeabures to ba installed, 


SAL Database Engine: MSSOL10.SALEXPRESS 
--. Instance Directory: C:\Program Fles{Micrasoft SL Server’, 
I Shared component rook directory 
Shared feature directory: C:\Program FleslMicrosoft SQL Server! 
- Errar ard Lsage Reporking 
`“ sage Reporting: True 
"Error Reparktimg: True 


Complete 


Setup Support Rules Ready to install SQL Serwer 2005: 
Liense Teris Edition: Express wth Advanced Services 

N aL ` Action: Install 

Seêneral Configuration‏ -3 ا 

onfiguration : - Features‏ و 
Disk Space Requirements . Database Engine Services‏ 

| Serwer Eonflgur ation - SOL Server Replicator 

, Database Engine Configuration ¬ Management Tools - Basle 

: ES -- SOL Clerk Connerly 5D 

| e E ahs EF Instance configuration 
installation Rules Instance Name: SOLEXPRESS 
Ready to Install “< Instance ID: SQLEXPRESS 
Installation Progress Instance IDs 


anfiguraton fils path: 
:1Pragram Files\Microsoft SQL Ser ver 1OMMSetup BootstrapiLog | 2O31 _1654 1 Eon figura tioniFilë .ini 


x Bark La J Lancel Help 


عند ذلك تبدء عمليه التنصيب بالمواصفات التي حددناهاء و تأخذ العملية بعض الوقت إلى ان تتم كما في الشكل التالي: 


f SQL Server 2008 Setup EE ا× ا۵ا‎ 


Installation Progress 


Seip Support Rules Selip process complete 
Product KEY | 
Licenses Terms 

Feature Selection 

Instance Configuration 

Gis Space Requirements 
Server onfîgur ation 
Database Engine Configuration 
Error and Llsage ReporFlrmg : 
Imtalation Rules ي‎ SL Client Connectiyky SOK 
Ready to Install 

Installation Frogress 

Carmpleke SOL Server 2008 


Please walt while SUL Sever ZUNS Selup processes the current operation, 
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والشكل التالي أيضاً: 


حسام كمال محمد 


ê SQL Server 2008 Setup 


Complete 


Your SL Server 200E installation campleted successfully, 


Information about the Setup operatioî of possblê next steps: 


I Your SQL Serwer 2008 installation completed successfully, 


(For informatian about how to use Microsoft Lipdate to Identify updakes For SQL Server 2008, see the Microsoft 
Web site http: go. microsoft.com ink? LinEId=1 08404 ak HEEp: go microsoft.com Felink LinkIA= 


108409 
Reporting Services 


Tha FannFrFina SEruirag inFallakian anFiana FhaF iru emnariFiagl in Sah ın daFermina uhethar afAifianal arf rata E 


Sebup Support Rules 
Pradiuct Key 

Lieense Terms 

Instance Configuration 
Disk Space Requirements 
Server Configuration 
Database Engine Zor figuratiofi 
Error and Llsage Reportirig 
Installation Rules 

Ready to Install 
Installation Progress 
Complete 


اضغط ميوه]1ء في الشكل السابق ٠‏ تم طونم لإنهاء التثبيت بنجاح كمال بالشكل التالي: 


ia Microsoft 5QL Server 2008 Express Download _ __ | اتا‎ × 


SOL Server 2008‏ حل 


SQL Server 2008 Express Setup Package 


Downloads and installs prerequisite software, ard then installs an 
instance af SQL Server 2008 Express, 


Installation completed successfully. 
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ویهذا نکون قد آنهینا عملية التشبيت بنجاح . للنسخة sئ٥٬مEx‏ ۽ والتی لن تختلف كثيرا عن النسخ المحترفة › 
يمكنك أيضاً أن تقوم بتثبيت 2010 دالا امںءا۷ بأي نسخة حسب اختيارك . ويمكنك الاستعانة بالبحث حال 


عدم توفر آي من هذه النسخ عندك لأنيى افترض فيك الجدية كمبرمج لتعتمد على نفسك حال مواجهة أية 
مشاكل في تثبيت منتج أو عدم موائمته مع إمكانيات جهازك او خادمك او البحث عنه للحصول عليه. 

يتبقى الجحزء اليسير وهو تثبيت فاعدتين البيانات اللتين سنتعامل معهما خلال الكتاب وهما القاعدتان 
lلمnشqورjli AdventureWorks 9 Northwind‏ يمكنك ان تحصلJ‏ 9اعıة‏ lilıl|lٽ AdventureWorks‏ من ھذا 
الرابط : 

http://msftdbprodsamples.codeplex.com/releases/view/37109 


: Northwind ٽlilal|l‎ ةدعاaل وهذا الرابط‎ 2008 Express 

http://northwı1inddatabase.codeplex.com/ 

بالضغط على زر ١دها"سه0‏ الموجود في يمين الصفحة . ثم اتبع خطوات تثبيتها أيضا من خلال وثائق 
الرابط نفسه او بالبحث عن تلك الكيفية (لم اشرع في شرح ذلك حتى تتعود الاعتماد على نفسك لأنك في 
طريقك لعالم البرمجة الأكثر احتراقا). 


بالمتابعة فى بداية الفصول القادمة ستتمكن من التعامل مع هذه البيئات الرائعة لتبدأً انطلاقتك نحو عالم 
برمجة قواعد البيانات. 
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الفصل الأول 


مدخل إلى كو اعد البيانات العلائقيه Relational Databases‏ 


حسام كمال محمد 
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فى هذا الفصل سوف تتعلم الآتى: 


ما ھی قر اعد البباتات؟ 

متى أخثار بين بر امح الجدارل الحسابية وبين قوأعد الببانات ؟ 
لماذا نستخدم قواعد البيانات ؟! 

فوائد استخدام نظم إدارة قواعد البيانات العلائقية R58 MS‏ ؟ 
الفرق بين 8R 58 MS‏ لأنظمة سطح المكتب و الخوادم sإم۷إمS‏ 
دورة حياة نظم قواعد llبlyنlٽت DB Life Cycle‏ 

إيجاد العلاقات بين البيانات 

فهم المفاتیح ysع)‏ 

Data Integrity ٽlنlيبll فهم تمامية‎ 

Normalization |آ—‎ ئدlڊم‎ 

مساو ئ Normalizationdl‏ 


حسام كمال محمد 
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ما هى قواعد البيانات ؟ 
بمنتهى البساطة فى تعريف قواعد البيانات نقول أنها مجموعة من البيانات المهيكلة Q4ءإنں)عءں)ء‏ أى موضوعة وفقا 


لمنظومة معينة »فالغرض الأساسى لأى قاعدة بيانات هو تنظيم معلومات كبيرة الحجم تيسيرا على المستخدم حال قيامه 
بعملية استعلام أو تعديل أو إضافة لهذه المعلومات . 


ما هو نظام إدارة قواعد llبlıنlٽ Data Base Management System ( DBMS)‏ ؟ 
هو عبارة عن برنامج لإدارة قواعد البيانات وإنشائها والتعديل فيها » أى هو أداة المستخدم فى فعل ما يشاء فى أى بيانات 
على حسب إمكانيات البرنامج » فمثلا يُمكن هذا البرنامج المستخدم من إجراء الاستعلامات (ستعرفها مامعنى الاستعلام 
لاحقاً) -الخاصة بإرجاع البيانات وعرضها فى جداول »أو التعديل عليها ....إلخ من العمليات . 


ما ھy‏ أ Relational DBMS‏ ؟ 
يستطيع ال 08۷5 من التعامل مع البيانات فى صورة جداول (صفوف أو سجلات _أعمدة أو حقول) تشبه تلكم الجداول 
فى البرامج المحاسبية مثل 8×1 وهى صورة سهلة ومنطقية لتنظيم البيانات » ومن هنا ظهرت قواعد البيانات العلائقية 
أو RDBMS‏ التی هی مربط الفرس اللآن فى التعامل مع البيانات فى معظم التطبيقات تو ءا كانت تطبيقات سطح المكتب 
أو ويب أو حتى أجهزة كفية . 
متی تختار بين قواعد البيانات والجداول الممتدة Spreadsheets‏ ؟ 
یأتی سؤال بدیھی..بما أن قواعد البيانات تشبه فى عملها الجداول الممتدة و{ءءطولوءإم؟ فلماذا إذا ظهرت ؟!! ....سؤال 
جيد » والإجابة تكمن فى المرونة التى يوفرها لك أى نظام إدارة لقواعد البيانات من استرجاع سلس وسهل للبيانات » إجراء 
العمليات على هذه البيانات مهما كانت مفرقة فى الجداول »إجراء عمليات على الجداول دفعة واحدة دون تجزئتها (كل هذا 
سيظهر لك لاحقا لاتقلق من المصطلحات إن لم تكن تعرفها ) . 
لماذا أستخدم قواعد البيانات ؟ 
توفر لى قواعد البيانات الحلول للعديد من المشكلات التى تقابلنى فى الحياة مثال : 
° لوچ چ 0 ا 0 و 0 0 و 00 او ي ا 
e‏ السرعة فى جلب المعلومة مهما كان حجم البيانات عندى »أسرع بكثير حتى ولو كان النظام الورقى التقليدى عندى 
مرتب بأی شکل کان . 
ه توفير الوقت والمجهود المبذولان فى ترتيب وتنظيم البيانات بالطرق التقليدية والتى بدورها معرضة لأخطاء 
كثيرة وجسيمة . 
° الإعتمادية فى جلب المعلومة ءفالبشر يخطئ نتيجة للضغوط اليومية فى العمل »وبالتالى وقت الازمات تظهر 
الحاجة إلى معلومات وبأقصى سرعة ءبطبيعة الحال لن تجد اسرع من البيانات المميكنة فى صورة قواعد بيانات 
وفاءا بطلبك فى زمن صارت فيه للثانية قيمة . 


فوائد استخدام نظم إدارة قواعد البيانات العلائقية R5 6١S‏ ؟ 


تستطيع ۸58۷S‏ من تحقيق فوائد جمة عن طريق التحكم فى الآتى : 
e‏ انتکكراري4 Redundancy‏ :فهى تمنع أى تكرار سواءا مقصود او غير مقصود لبيانات موجودة مسبقا وبالتالى تتحكم فى 
توفير وعدم إهدار المساحة على القرص الصلب او أى وحدة تخزين اخرى. 
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ه تضارب البيانات yعمماءزىرمءم[‏ :من الفائدة السابقة نحقق ضمان عدم تضارب البيانات ودقتها فمتال »لو أنك أدخلت 
اسم نفس الشخص الرباعى مرتين مثلا فهناك احتمال للخطأ فى أحدهما مع أنه نفس الشخص مما يوحى بوجود 
شخصين مختلفين »فالتحكم فى تكرار البيانات وادخالها يلغى هذه المشكلة من الأساس . 

تكامJ‏ İlڊIilgت :Data Integrity‏ فالنظام يحقق نوع من الانسجام بين البيانات يمكن من خلاله استخراج معلومة 
صحيحة (سيتم مناقشة قضية تكامل البيانات تلك لاحقا) . 

ه تدارك الخطأً :فى حالات فشل اتمام أى عملية كتحويل الأموال مثلا أو الولوج إلى أنظمة سرية مثلا أو حتى العمليات 
المزدوجة كإجراء تعديل من قبل شخصين على نفس البيانات فى نفس الوقت هناك خط دفاعى لتدارك هذه المشكلات 
عن طريق .۸D58 MS‏ 

ه تأمين البيانات : ليس كل شخص يتعامل مع البيانات مخول له القيام بعمليات كاملة على البيانات ءفهناك أشخاص 
لعرض البيانات فقط »وآخرون لإجراء تعدیل عليها »وأخرون لديهم كافة الصلاحيات من حذف لهذه البيانات والتعديل 
.......إلخ من العمليات . 

ه العمليات المنتظمة واستراجع الأخطاء: فى بعض الحالات يكون هناك تسلسل لعمليات مختلفة على قواعد البيانات 
يستطيع MS‏ ۸28 من هذا »فضلا عن استرجاعه لهذه العمليات حال حدوث خطأ مفاجئ لا قدر الله. 

ه تنظيم التخزين: يمكنك ۸28۷S‏ من تنظيم للبيانات المخزنة على وحدات التخزين المختلفة بميكانيكية تسهل عمليات 
الاسترجاع والبحث عن طريق مايسمى بوصعطء؟ اورإم٤م]‏ دون تدخل منك . 


الفرق بين ۸R [85S‏ لأنظمة سطح المكتب و الخوادم ءإم۷اآم؟Š‏ 
تنقسم صناعة البرمجيات اليوم المتعلقة بقواعد البيانات تقريبا إلى قسمين رئيسيين : 
ه قواعد بيانات أنظمة سطح المكتب او و٣‏ . 
ه قواعد بيانات أنظمة الخوادم وإمرإمS.‏ 
فيما يلى الفروق الجوهرية بين النوعين : 
قواعد بيانات أنظمة سطح المكتب او وئ€٣‏ 
تتسم قواعد بيانات أنظمة سطح المكتب او و٣‏ بقلة عدد المستخدمين او بالأحرى المنتفعين من قاعدة البيانات عن طريق 
أنظمة رخيصة نسب Jû‏ آ— ) (MS Access -Lotus-FoxPro-SQL Server Express‏ 
وفى الغالب لا تتضمن هذه الانظمة العلميات المعقدة او الإمكانات الكبيرة نظراً لعدم الاحتياج إليها على أنظمة سطح المكتب 
فھی تلائم المؤسسات الصغيرة والمتوسطة الحجم بمنتهى الفاعلية > لكنها تختلف عن أنظمة الخوادم فى الآتى : : 

ه أرخص كثيرا : فبالقليل من المال تستطيع اقتناء رخصة لحزمة كاملة كالأوفيس متضمنة برنامج الأكسس وبالتالى أنت 
والمستخدم النهائى فى غنى عن المساءلة القانونية عن رخصة نظام قواعد البيانات الملحق ببرامجك وهذا الأمر هام 
SS‏ و البيانات فى السوق . 
مثلا وتبداً فى التنفيذ » دون ا استعلامات SQL‏ کک oT‏ 


قواعد بيائات أنظمة الخوادم Servers‏ 

على العكس من أنظمة قواعد البيانات الخاصة بسطح المکتب »› تتسم قواعد بیانات ال مم6 بالتعامل مع كم كبير ومعقد من 

البيانات دفعة واحدة »ليس هذا فحسب بل ومن أكثر من مستخدم فى نفس الوقت دون أى خلل وهذا يرجع إلى طبيعة الخوادم 

وإماكانياتها الكبيرة مقارنة بالأجهزة المنزلية العادية وكمتال على قواعد بيانات الخوادم هناك العملاق أوراكل وركذا [إQ@؟ MS‏ 

. Sybasey IBM D82 ةsرش و أنظمة‎ Server 

ويكمن الإختلاف الجوهرى بين هذه الانظمة وسابقتها فى الأتى : 

ه المرونة : وحقيقة هى من أهم ميزاتها ءفقد تم تصميم هذه الأنظمة لتلائم وبمنتهى المرونة أنظمة التشغيل المختلفة 

كالويندوز واللينكس واليونكس ولتتلقى العديد من الاستعلامات فى ذات الوقت وتتعامل معها بمنتهى السهولة والسرعة 
أيضا 
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© الإعتمادية توفر قو اعد بيانات ا ج نظمة الخوادم Servers‏ القدرة کل الاعتماد عأيها بدرجة 2 ساعة طيلة ۷ أيام 
متصلة طبقا لحاجة السوق إلى ذلك ..مثال هذا أنظمة البنوك والشركات العملاقة كميكروسوفت وكموقع كبير كأمازون 
مثلاٌ فهى عادة ماتلحق ببعض الميزات مثل Log Shipping ls Mirroring‏ . 

ه سرعة الأداء : لأنها تعمل على اجهزة الخوادم فهى تتسم بالسرعة العالية فى الاستجابة للأوامر والعمليات المختلفة › 
فأجهزة الخادم دائما ما تلحق بحجم كبير من الذاكرة وسعات التخزين » مما لاشك فيه يوؤثر بالإيجاب على السرعة 
والدقة المطلوبة. 

ه التمدد : من الميزات المهمة جدا ميزة التمدد والاستعداد الدائم للطوارئ والزيادات فى أى وقت فى حجم البيانات 
وكثافتها » نخيل مثلا لو أن بنك فى اليابان كان حجم تعاملاته اليومية ٠١‏ مليون عملية تم دمجه مع بنك اخر حجم 
تعاملاته ٠١‏ مليون عملية » إن لم تكن قواعد البيانات مهيأة تماما لمثل هذه الإإجراءات الطارئه ...فالخسائر ستكون 
فادحة فى العملاء 


دورة حياة نظم قواعد البيانات D8 Life Cycle‏ 


كما فى عالم النبات والحيوان دورة حياة › أيضا فى عالم البرمجيات دورة حياة للمشاريع ابتداءا من التصور وانتهاءا بمراحل 
كالتوزيع واصدار الترقيعات ....إلخ . 

كذا فى حالة نظم قواعد البيانات يبدا التطوير بالفكرة ثم التنفيذ »والذى بدوره ينقسم إلى عدة مراحل » لايتم الانتقال إلى مرحلة 
إلا بعد تجاوز المرحلة السابقۂ لھا (Block by Block)‏ . 

قبل الشروع فی تصمیم ای نظام »لابد وأنك تعمل وفقا لنموذج قیاسی معين Model‏ »والذی بدوره یحوی كل الخطوات اللازمة 
لبداً تنفيذ فكرتك البرمجية وبالتالى فلن يواجه فريق التطوير أى مشاكل تعترضه من تداخل فى الأفكار أو العشوائية فى التنفيذ 
وضمان جودة برمجية عالية . 

تنقسم دورة حياة نظم قواعد البيانات إلى عدة مراحل ءبدءاً من ال وصعطعء اھطہاع وانتهاءا بالتنفیذ والصيlنة maintenance‏ : 

ه تحليل المتطلبات وزورادره :R ميں٣٠” ٠۸۲‏ قبل الشروع فى التصميم لابد وان أعى المشكلة المراد حلها بقواعد 
البيانات جيدا »بتطلب هذا عدة لقاءات مع المستخدمين أو الموظفين من خلالها يعرف كيف يدار النظام »> ومنل أين وإلى 
أين تتدفق البيانات بهذه الطريقة تضمن توافق تنفيذك لمشروعك مع متطلبات العميل (هده المرحلة بحق ھی عصب أی 
مشروع برمجی). 
»فابستخدام العلاقات والنمادج ER diagrams Jin‏ نستطیع تو ضیح هده العلاقات والترابطات بين البيانات. 

e‏ التصميم الحقيقى :Physical design‏ من تم الانتهاء من التصميم المنطقى ال هده المرحلة الهامة وهی وضع 
الجداول وإختيار المفهرسات وءإمء×م يو[ لإكمال البنية الهيكلية لقاعدة البيانات. 

ه مرحلة بناء قاعدة البيانات : هنا يبدأ المجهود السابق يثمر عن قاعدة البيانات الحقيقة التى ستستخدم فى مشرو عك 
مستخدمين نظام إدارة قواعد البيانات العلائقية R586 MS‏ (فی الحقيقة سنستخدم مایعرف ب 551 وهی إختصار ل 
Data Definition Language‏ ستعرف هذا لاحقا إن شاء الله) 

ه مرحلة التعديل على البيانات رoن†aءfiنقهمص Data‏ : باستخدام لغة التعدیل على llبيlنlٽ Data Modification‏ 
DML gy Language‏ تستطيع اجراء الإستعلامات وإنشاء المفهرسات وتحديث قا عدة البيانات ووضع القيود مثل 
التكامل المرجعى Referential Integrity‏ . ٍ 

e‏ مراقبة قاعدة البيانات Monitoring‏ مههtهD:‏ وتعتبر هذه المرحلة هامة جدا بعد عمليات التنفيذ السابقة »ضمانا 
لتلاقی التنفيذ مع المتطلبات المنشودة »ففی حال وجود مشاکل أو ظهور خطا ما فى التصميم عن طريق المراقبة 
تستطيع تلافى هذا الخطأ بالرجوع إلى الخطوات السابقة وإجراء التعديل اللازم .وهكذا دواليك تستمر دورة حياة قاعدة 
البيانات بالوصول إلى هذه المرحلة ثم العودة ثانية إلى المراحل السابقة إذا لزم الأمر . 
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اإيجاد العلاقات بين البيانات 


تعتبر الجداول الشكل المبدئ لقواعد البيانات العلائقية فى الواقع يتم تخزين البيانات وعلاقاتها معا فى قاعدة البيانات فى 
جداول. 
تتكون الجداول من صفوف وأعمدة » كل عمود يعبر عن معلومة جزئية . 
فى قواعد البيانات لابد وأن ترتبط الحقول أو أى جزئية من البيانات مع بعضها البعض بعلاقة ما . 
ا قم آل ترات نے رک ما + هات مورکون دارگ واضات تت تخا عد ف قاع ات للك الس إلى 
غدۂ غلاقات مو ضح کے التالے : 

م العلاقة ‘One-to-One‏ تعنى أن قيمة واحدة فى الجدول أ مثلا تقابلها قيمة واحدة (صف) فى الجدول ب انظر الرسم : 


فمثلا لکل قسم یو جد مدير واحد فقط .. لذا یتم ربط جدول المديرين بجدول الأقسام عن طريق ل ر 


ه العلاقة وروج۷-ه0)-ءم0 : تعنى أن قيمة فى الجدول الأول تقابلها قيمة فى الجدول الثانى وهذه القيمة بدورها يقابلها 
قيمة أو اكثر فى الجدول الأول ... 


مثال على ذلك طلبات الزبائن على سلع أو منتجات معينة ..فالزبون الواحد مخول له شراء عدة منتجات مختلفة وكذا نفس 
العلاقة من السلع للزبائن اى أكثر من زبون يحصل على نفس السلعة . 


... تعنى أن قيمة فى الجدول الأول تقابلها قيمة أو أكثر فى الجدول الثانى والعكس صحيح‎ : Many-to-Many قںعÛl‎ e 


فمٹاد فی ڪول الطلاب تطیہ الطالب ألذت جبا ک أكثر من ماده › وجدول المواد الدراسية يستطيع أن پسجل العديد من 
الطلاب ألمادة أو أكثر . 
فى الغالب عند تنفيذ هذه العلاقة يكون هناك جدول ثالث للربط بين الجدولين لأن هذا النوع من العلاقات معقد نوعاما. 


فهم المفاتیح رم 
عرفنا أن تمثيل العلاقات يتم بين البيانات فى الجداول وفقا لطبيعة العلاقة » ولإيجاد هذه العلاقات لابد من وجود صفوف أو 
حقول مثلا للربط بين هده الجداول ¢ وامثل علاقة بين هده الجداول ھی المفاتيح Keys‏ » هه المفاتيح ماهھی الا أعمدة 
متشابهة بين الجداول وذلك لتمييز الصفوف بعضها عن بعض . 
ى RDBMS‏ يتعامل مع نو عين رئيسيين من lnllتيz‏ : Primary Key (P.K) , Foreign Key (F.K)‏ : 
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:۲.× المفتاح الرئيسي‎ .١ 
هو عمود او أكثر » يتصف بأنه غير حاوى لبيانات متكررة أى بيانات فريدة مں ونمل مميزا به كل صف فى الجدول .تنبه إلى‎ 
‘PK الآتیى عندما د تختار مفتاحا رنڊ یسیا‎ 


ه كل سجل فى الجدول لابد ألا يحتوى على قيمة خالية 1ا NU‏ . 

ه كل قيمة مدخلة إلى العمود الحاوى للمفتاح لابد أن تكون قيمة فريدة كما أسلفنا. 

ه ضمان الحفاظ على القيمة الموضوعة فى الجدول من عدم التغيير مستقبلا أثناء اجراء العمليات على قاعدة البيانات . 
ه يوجد فى الجدول مفتاح رئيسى واحد فقط . 


إلى جانب ضمان المفتاح الرئيسى ۴.1 لفرادة البيانات الموجودة فى كل سجل » فهو أيضا يسهل عملية البحث داخل الجدول 
وذلك لأنك بمجرد انشاءك للمفتاح الرئيسى يتولد اتوماتيكيا فهرس للجدول يسهل عليك عملية البحث وبالطبع هذا كله يعود إلى 
RDBMS ÛJI‏ . 

ليس هذا فحسب بل من الممكن أخذ أكثر من رازہ٤‏ واعتبارھا مفتاح رئیسی وذلك تحقيقا لمبداً الفرادة Uniqueness‏ 
ويسمى هذاءكما أنه يمكن ترشيح اى مفتاح ليصبح مفتاحا رئيسيا (وفقا للصفات السابقة الذكر) ويسمى هذا المفتاح المرشح 
Candidate Key‏ . 


: Foreign Key المفتاح الخارجى‎ 

المفتاج الخارجی .۴ عبارة عن صفة مرجعية للمفاتيح الرئيسية ..أو قيمة غير مكررة (مںوذمل) فى جدول آخر وهى هامة 
جدا فى تحقيق خاصية التكامل المرجعى والتنقل بين عناصر الجداول المترابطة ..انظر الشكل للتقريب ..ولاتنس ان الأمر 
مجرد تنشيط للذهن ومراجعة لما تعرفه سابقا . 


Biuudleiil 


LHI] 2= 32 AIEEE Fil 


HÎ «10Î ل‎ | 2-e [OB EIT 


Cm | Comoe _ 


لاحظ أن ال مكه٤_مء0‏ فى الجدول الأصغر مفتاح رئيسى ..وفى الجدول الأكبر مفتاح خارجی .۴. 


فهم مام نٽ Data Integrity‏ 
وتعنى ضمان صحة قيم بيانات قاعدة البيانات وكذا ارتباطها معا .وهی تنقسم Integrity gs Entity Integrity jڍanıق JJJ‏ 
.Referential‏ 


° أولاً: Entity Integrity‏ 
ذكرنا فى الشرط الأول من شروط اختيار المفتاح الرئيسى ألا تكون القيمة خالية 1[ وهذا لضمان وجود قيمة على طول 
المفتاح الرئيسى فى كافة الصفوف » هذا الضمان هو مایعرف ب راذاعم)ہ] ران) ٤‏ »حيث يقوم ال D88‏ بمنع إجراء 
استعلامات (ءمtدلما-۲إءءہ])‏ إلى المفتاح الرئيسى متضمنة قيمة مكررة أو غير فريدة . 
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° ثانياً : Referential Integrity‏ 
عندما يتم انشاء الجداول وإيجاد العلاقات بينها فى قاعدة البيانات ءيتم اختيار المفاتيح الخارجیة .۴ والتی عن طریقھا یتم 
إدارة العلاقات بين الجداول تحقيقا لمبدء التكامل المرجعى 1[ »فهو يضمن أن کل قيمة فى المفتاح الخارجی .۴ تقابلها قيمة 
فی جدول اخر للمفتاح الرئیسی .P.K‏ 


فهم مبادئ آ Normalization‏ 


ال iationاaصNor‏ باختصار شدید هی منع تکرار البيانات أو الزج ببيانات ليس لها داع فی أثناء قيامك بالتصميم المنطقى 
لقاعدة البيانات »وبهذه الطريقة توفر على نفسك عناء التحديث المستقبلى لقاعدة البيانات » فضلا عن سر عة الاداء بعد التنفيذ 
الفعلى لقاعدة البيانات .بالطبع عملية كتلك تمر بعدة مراحل إلى ان تصل الى النموذج المعیار٦٣ى 3NF Third Normal form‏ 
وھذہ المراحل اذا اردنا تشبیھا بلیغا لها فهى مثل عملية الغسيل ثم الشطف تم الشطف النهائى © » يمكنك الاستزادة بقراءة 
المزيد عنها هنا .http://en.wikipedia.org/wik1/Database_normalization‏ 


مساو ئ اف Normalization‏ 


بطبيق مبادئ ال «منادنادد_إهN"‏ يصبح عندنا مجمو عة كبيرة من الجداول وكذا العمليات الوصلية(ومذه3) لإسترجاع 
البيانات» وبما أن البيانات موز عة على الجداول فيما بينها »فان مثل هذه العلميات تكون معقدة وبالتالى ترهق عملية المعالجة 
وتستنزف وقتها »فمن الممكن وقتها نتخلى عن بعض مبادئ ال «منادرنادص_إهN‏ فى سبيل التخفيف عن المعالجة بعض الشئ 
ءتذكر أن الغرض من هذه العلميات ماهو إلا الوصول إلى التصميم الأمثل لقاعدة البيانات تجنبا لمشاكل الأداء والتحديث 
المستقبلى . 


خاتمة الفصل 

تذكر أن الهدف من هذا الفصل كان تنشيط الذاكرة ليس إلا ببعض ما درسته أنت فى السابق سواء مع 
نفسك أو فى فصول الجامعة . فإذا وجدت انها ثقيلة عليك نوعا ما ومملة ...لا تقلق أبدا فهذا لن بعيقك 
لتكون مبرمج قواعد بيانات محترف ..وسوف تكتسب كل هذا بالخبرة إن شاء الله ...فقط تابع المسير 
فالقادم أسهل بكثير . 


کما 
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الفصل الثانى 


كتاية استعلامات قو اعد البيانات Database Queries‏ 
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فی هذا الفصل ستتعلم 
كتابة الاستعلامات داخل 2008 SQL Server‏ »والتعرف قل اللغة الداخلية T-SQL‏ المسئولة عن كتابة هذه 
الاستعلامات ٬بالاستعانة‏ بقاعدة بيانات شهيرة مJû „Adventure Works yi North wind‏ 
باذن الله سيغطى هذا الفصل الاتى ... 


QBE and SQL المقارنة بين‎ 

SQL Server Management Studio Express ”ذeE‎ فرعتلl‎ 
Quعrزعs التعرف على الاستعلامات‎ 

اجراءات وأوامر الأتعامل مح الجداول 

GROUP BY ûlnج‎ 

PIVOT Jماعaلا‎ 

ROW_NUMBERO) all 

PARTITION BY élnج‎ 

Pattern Matching فم آ‎ 

Aggregate functions gıaجتll‎ JI دو‎ 
DATETIME functions خıرlتll, دوال الوقت‎ 
JOINS 
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المقارنۀ بین QBE and SQL‏ 
لکی نتعامل مع قواعد البيانات العلائقية هناك نو عان من اللغات لأتواصل بين المستخدم وبين قاعدة البيانات (QBE- aay‏ 
.(SQL‏ 


QB€‏ :ھى اختصار الجملة Query By Example‏ وهی طريقة لاجراء الاستعلامات کان قو اعد البيانات معتمدة گے الواجهه 
الرسومية معتمدة على مبداً (kعزاC‏ ل مھ ٤ہزہم).لقد‏ تم تطویر Q8۴‏ علی ید موشی زلووف فی معامل MN‏ 18 بالتزامن مع 
تطوير 8Q]‏ فى منتصف السبعينات » وهى تختلف عن _80 فى سهولة اجراء الاستعلامات معتمدين كما قلت على الواجهة 
ادارة فر اک الانات :وفے طر ا تقر مال فى كال فر أ“ انات الغر معقة ر الت نمثلا بالفدل من الجذازل. 
وعلى الرغم من انها تطوير شركة 18۷ إلا أن شرکات کمیكروسوفت قامت باجراء بعض التعدیلات علیها واستخدامها فى 


:SQL‏ هى اختصار للجملة ›Stkructured Query Language‏ و ھی لغ تم تطوير ها فى معامل 18M‏ ايضا من قبل مجمو عة 
تطویر فی مرکز ابحاث سان جوز- شامبرالن وریموند - وهی اساسا قد تم تطویر ھا للتعامل مع نظام قواعد بیانات یسمی 

System ۸‏ وهو نظام مبنی على فرضيات ١‏ له » ولمن لايعرف فان لله هذا يعتبر الأب الشرعى لقواعد البيانات العلائقية 
بعد نشره ورقة بحث يوضح فيها الأسس والأطر لهذا النظام الجديد. 

فی عام ۱۹۸٩‏ تم اعتماد لغة 1ا؟ من قبل ۸1 و أیضا من قبل 0 عام ۱۹۸۷ وتم نشر اللغة على وضعها القياسى هذا 
تحت اسم 5411 .ومن هذه الانطلاقة و سكول أخذة فی التطویر ففی عام ۱۹۸۹ وعام ۱۹۹١‏ تم عمل نقلة نوعية فى اللغة ثم 
مع العام ۱۹۹١‏ واصدار 8013 التى دعمت مميزات كالأهداف الموجهه والتى كانت نواه لقواعد البيانات الموجهه بالكائنات 
.Object Relational DB‏ 

وعلى الرغم من وضعها ا8 كمعيار لكن هناك شركات مثل اوراكل وميكروسوفت اصدرت انتاجها الخاص من اه8 
تيسيرا لبعض المهام على قواعد البيانات الخاصة بها » وفى كافة الاحوال فهذا لايختلف كثيرا عن الاصدار المعيارى من امS؟‏ 
ومثال على ذلك 1-01 المستخدمة فى هذا الكتاب » ربمالن تعمل اذا حاولت اجراءها على قواعد بيانات اخرى بخلاف _اSQ؟‏ 


.—Server 


تنوية٠‏ أعلم أن رووسكم قد تصدعت من هذه النبذة التار يخبة ولكن هنك فوائد كثبر ة ستخر ج منها من هذه النبذة وهى ابضا 
لايقاف بعض الجدل حول لغة $01 . 
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البدء مع كتابة الاستعلامات sعاrمQu‏ 


كرف مط ااا :هر عمل اتذلاض اعمات من اغلاات مرم ذلك ر حر د مت ر د كاه 
الاوامر او الاستعلامات کے نستخلص البيانات من قاعدة البيانات. 

هيا بنا نشمر عن ساعدينا ونبدأً بكتابة أول استعلام لنا » لكن قبل ذلك تأکد ja‏ وجو¬ SQL Server Management Studio‏ 
Express‏ والدی سنشیر له دوما 4— SSMSE‏ (راجع الملحق لکی تتعلم كيفية تثبيته والتعامل مع نوافده). 


جرب هذهء ڏ تنفيذ استعلام بسيط 


.Adventure Works database رjتخls‎ Databases Î تم قم بتمديد شجر ة‎ SSMSE افتح‎ ١ 
كما با لشکا ( واکتب هذا الا ستعلام بداخل النافدة الل ستظهر أك‎ New Query اضغط اي الزر‎ ۲ 


Select * from Sales.SalesReason 


| E Microsoft SQL Server Management Studio Express ت‎ | | 
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اه 4إ‎ 3; ORCASBETAZ_VSTSISQLEXPRESS [3.01 SFA) ORCASBETA2_VSTSAdministrator [e 


۳ اضغط عل Execute J)‏ او اضغط F5‏ او اختر قائمة Query -> Execute‏ ليظهر ناتج الاستعلام كما بالشكل 


C# 2010 and MSSQL Servef 2008 برمجة قواعد البيانات باستخدام‎ 


حسام كمال محمد 


5 Microsoft SL Sery¥yer Management Studio Express 2 | |× 
Fil Edl Yew Huery Tools Window  Zomrmunity Help 

Fa | e ES OOTY ا‎ 

: Î Hew Query | FN 3 ج أ‎ FT eEERE ê 0 ا‎ 

WE Û Î | AhetueNake Leet y E SESI BSA BEB 21 _ 


bject Explore FH * 


EEE 
= ا‎ RLASEETAZ_YSTSISQLERPRESS (SF 
Fl J Databases 
J SYstem Databases 
الا‎ Adyenturew'arks 
|| Northwind 


„* ORCASBETAZ_Y¥...LQuery1.sql* | Summary 


2ElEZE " fFom Sales. SalesEeason 


Î Results | j Messages 


1398-0E-Û1 0 


۴ 
2 MRLASBE TAZA YS TSMSHLERPRESS [3.0 SPA] ORCASBETA2_VSTS Administrator [e 


کد E a SalesReasonlD | Mame ReasonType | Modiiedl ale‏ فا 

Price Other 1338-06-01 00:00:00.‏ | 1 1 و و 

L_J FEeplicatian EEE MEENEIE 

J] Management 2 2 Ln Pramaltion Promotor 1338-DB-U OU:OO:OU.L 
LN £ Magazine Advertisement Marketing 1338-06-U OUDOUOU.L 
4| 4 Televislan Advertisement Marketing 1338-UB-Ul OUOD:OD.L 
ا‎ 3 Manufacturer LIther 1338-0-1 OUOU:OU.L 
E . Reye LIther 1338-06-1 OU:OD:OU.L 
1 1 Lerma EYent Marketing 1338-UB-U OUOUOU.L 

. Sponsorship Marketing 


لشرح ماحدث ببساطة فإن النجمة * مع كلمة S218 ٣1‏ تشير الى ارجاع كافة الأعمدة من الجدول المراد عمل استرجاع 


لبياناته. 


اجراءات وأوامر التعامل مع الجداول 


والتی سنشیر الیھا ب ٥1۴٤‏ أو sرExpressio Common rabe‏ وھی خاصیة جدیدة تم اضافتها الى 2008 Q1 Server‏ وهی 
ببساطة حالة مؤقتة من اجراءك لاستعلام معين مثJ SELEC1 , NSERT,DELET UPDATE‏ وتظھر میز تھا جلیا حین تقوم 
بعمل استعلام ما على جدول تم اشتقاقه بدلا من استخلاصها فی جدول موقت ثم اجراء الاستعلامات عليه ثم حذفه › کان هذا فى 
ا ا 


تتکون ال 1۴ من ثلاثة أجزاء رئيسية 


١۔‏ اسم ال C1۴‏ ملحقا بكلمة W1١8.‏ 


۳- الاستعلام الذى يظهر بين القوسين ( ) بعد كلمة ۸8 
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مثال يشرح ذلك 
افتح گڅSSMS‏ ثم اکتب هذا الاستعلام : 


WITH TopSales (SalesPersonIlD, TerritoryID,NumberOfSales) 
AS 

( 

SELECT SalesPersonlD, TerritoryID, Count(*) 

FROM Sales.SalesOrderHeader 

GROUP BY SalesPersonlD, TerritoryID 

) 

SELECT * FROM TopSales 

WHERE SalesPersonlD IS NOT NULL 

ORDER BY NumberOfSales DESC 


ا وی اا که اکل 


ا× اھا 


|= 


lı 


` BB 2| El = 


WITH TopSales [BSalesPersaonlD, TeEFitoryYlID, WiurberifSal 


SELELT SalesPerszonlD, TerritorylDl, Lount l*] 
FELM Sales. Salesirder Header 
TerriltoryID 


WHERE SalesPerszonlD I15 HOT NULL 


Microsoft SQL Server Management Studio Express‏ ا 


Fila Edt Yim  Guery Winda  Lormrmunity Help 
: ی‎ e۷ e | ا 2 ا‎ #8 
: a چ‎ 1 | Adventure works 


ibject Explorer 
3 3 a 3 T 
=1 | ORCASBETAZ_VSTSISQLEXPRESS (SC 
EI KJ Databases 
I SYstem Databases 
۲ AdyentureWorks 
lJ Northwind 
O Security 
O Server Dbjacts 
a Feplicatian 
DO Managerment 


Tools 


” | f! Execute qy’ WM ا‎ 


س ا ا 


ORCASBETAZ_Y...LQuery1.5ql* 


ا 


TROUFP BF SalesPeraonlID, 


SELELT * FREON TopBales 


DREDER ET MumbperifBales DESL 


فى هذا المتال الذى حددنا اسم ۳ع له وكذا الاعمدة الثلاثة (SalesPersonID,TerritoryID,NumberOfSales)‏ نلاحظ ان جملة 


SELECT SalesPersonlD, TerritoryID, Count(*) 


هى الأخرى ستعود بناتج ثلاثة أعمدة والعمود المنفرد المخصص من ءا S818 ٣1‏ سيشير الى الأعمدة التى تم تخصيصها 


فی توصیف ال C1۴‏ . 


ENE E NNE EN UE EN AO EN EET NEE 
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GROUP BY ûأlnج‎ 


تستخدم هذه الجملة لتنظيم الصفوف وس١٠8۸‏ الناتجة من استعلام معين الى مجموعات » واجراء جملة S٤18٣٤٣1‏ على 
التعامل معها » وانت تريد تقرير باجمالى القيمة لكل شركة على حدة » جملة ٥8۷‏ 1۲ا۸0 هى ما تبحث عنه لذلك. 


مثال على ذلك 


افتح SSMS۴‏ واكتب هذا الإإجراء 


Use Adventure Works 
GO 


Select CardT'ype, Exp Year,count(CardT'ype) AS "Total Cards! 


ثم قم بعمل م{ںcم×۴‏ ولاحظ الناتج کما بالشکل.۰ 


Eila Edl Yim query Tools Window  Lormmunity Help 


: Jue oer | | ê HH #| Ê Û 


BEF 
“| f ente vı E SSE lS BS E BO 2E 
DORCASBETAZ_¥...LQuery1.sql* 
Use LAVENTUFEWDOEKS 
En) 
EleECTL LardAType, ExpTear, count I(LardAType)l ABS ' Total 
from BSalez.LreEAitLard 
Where ExpTear ir IlêEUUÖ,ZUUT] 
HEOUp by ExpTYear , LarFATYFpE 
ourAEr pyr LardTypeE, Exp Tear 


i Results | 3 Messages | 

E#pTear j Total Cards 
1__i Calomialaice | 20056 1223 
2 | Coloniavoice 2007 1174 
_3_ | Distinguish 2005 1208 
4 | Distinguish 2007 1282 
En Superlorard AUB لاك2ا‎ 


E | SuperiorCard 3ا لالات‎ 


1 | Yiska 216 114B 


3 | Yisla #لالا‎ #7 


RK Microsoft SQL Server Management Studio Express 


from Sales.CreditCard 

Where ExpYear in (2006,2007) 
group by ExpYear,CardT'ype 
order by CardT'ype,Exp Year 


: 2 لھ‎ 1 | Adventurewyarks 
ibject Explorer 
3 3 a 3 T 
E1 (j ORCASBETAZ_VSTSISQLEXPRESS SC 
El O Databases 
I System Databases 
ا‎ Adventure Works 
LJ] Northwind 
KO Security 
O Server Dbjerts 
a Feplication 
DO Management 


مأحدث ھو اجراء استعلام عل الجدول CredıtCard‏ من قاعدة البيانات Sales‏ لتعود گن صورة ثلاثة أعمدة مع اأدالة Count‏ 


التى ستعود بعدد أنواع الكروت فى الجدول 


Select CardT'ype, Exp Year,count(CardT'ype) AS "Total Cards' 


from Sales.CreditCard 


ثم قمنا بعمل حصر للكروت التى ستنتهى فى الفترة من 2006 الى 2007 عن طريق الشرط WHERE‏ ۰ تم تأتى جnذãة GROUP‏ 


: معا‎ ExpYear ڍ‎ CardType jlدومعلا لتعرض‎ B+ 
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group by ExpYear,CardT'ype 


أما جملة 8۷ 0۸5٤۸‏ فهى تضمن ترتيب الناتج اعتمادا على شرط معين وفى حالتنا هنا الترتيب سيكون ابجديا على 


العمود مم رآ ٥إھ٤‏ کاعتبار اول وعلی ۲و٥۲م×E‏ کاعتبار تانی. 


P]۷01 المعامل‎ 


تظهر ميزة استخدام المعامل P1۷01‏ فى حالة عمل جدولة لتقارير فى صورة ملخصات للبيانات » مع انه جرت شهرتها فى 
عملية تحويل بيانات الصفوف الى اعمدة › على سبيل المثال لو أننا أجرينا استعلاما على الجدول CreditCard‏ .ا فی قاعدة 


البيانات Adventure Works‏ لحصر عدد كروت الائتمان من نوع معين والتى ستنتهي فى تاريخ معين. 
فمثلا فى المثال الخاص بالجملة 8۷ 6۸0۲ لاحظنا تكرار لصفوف تحوي التاريخين ٠٠٠٠١‏ و ۲٠٠۷‏ باستخدامك المعامل 


1 بُختصر هذا الأمر الى صورة أكثر فهما وتنظيمات, 


مثال على ذلك 


ماذکرناه أعلى » نر يد أن نجري استعلاماً على الجدول إإه))1لعإ٤.ءء1هS‏ فى قاعدة البیانات Aventure Works‏ لحصر عدد 


التالية ثم اضغط ع{ںcم×8.‏ 


Use Adventure Works 
GO 


select Card T'ype ,[2006] as Year2006,[]2007] as Year2007 


سرف تلاحظ تيجة كما باشكل التالي: 
f Execute yî BM Sw Ll Bla. a E | 43 EAL‏ 


4 


ORCASBETAZ_Y¥...LQuery1.sql* 4 
Use AAFEnNTUFEUOE K3 ۳ 
co ۳ 
ze leEZL LardAType ,[2UU] as TeEarzdlUlê, [2UU?] as TearzlUl 
EE OI 


1 

ze leEZL LarAType, ExpYTear 

Eroam SalEez.LEEAITCLAaAFA 

I1pliw Piwot 

1 

Zoaunt [ExpYTear]l for ExpYear in I[2UUé], [20U] 
1as carFAdePtai l 
oFAeEr phy LardType 


Results | 3 Messages | 
Tearêllb | TeardUUr 


Lolonialyoilce ; 1 EE 1174‏ ا 
122 8اك 5 Distinguish‏ ا 
Superlolard | 122l 1223‏ | 


4 | Ista 114E 1i#F 


from 


( 
select Card T'ype,Exp Year 


from Sales.CreditCard 
Jpıv Pivot 


( 
count(Exp Year) for ExpYear 1n ([2006],[2007]) 


Jas carddetaıl 


order by CardT'ype 


Adventure wYorks‏ | 4 ا ا 
bject Explorer‏ 


= | ORCASBETAZ_YSTSISQLEXPRESS {5C 
E O Databases 
DO 3Ysterm Databases 
ا‎ AdyentureWwarks 
lJ Horthwind 
KD Security 
KI Server Objects 
OO Replication 
CO Management 
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لشرح ماحدث ببساطة أجرينا استعلاماً مستخدمين جملة 4518٣1‏ مع الأخذ فى الاعتبار تغيير المسمي الحقيقي للأعمدة الى 
7مم ر, 2006ع تم اجرينا نفس الاستعلام مع انواع كروت الائتمان وتاريخ نهاية الصلاحية ثم ختمنا الجملة بالمعامل 
P1‏ ءثم استخدمنا COUNT alll‏ والتى تحصى عدد الكروت المنتهية فى العامين ۲٠٠۷-٠٠٠١‏ تم ختاما ستخدمنا جملة 
ORDER BY‏ والتی رتبت بناء ا“ على الدليل التالى لها وهو هذه المرة CardT' ype‏ . 


hlأأ ROW _ NUMBER‏ 
هى دالة تقوم بحصر عدد الصفوف فى جدول معين بحيث تعود برقم صحيح فريد غير قابل للتكرار. 


مثال على ذلك 
افتح نافدة استعلام جديدة فى MSE‏ اکتب الإستعلام التالي واضغط مع{ںم×ع او ۴۳5 ولاحظ النتيجة ٠‏ 


select SalesPersonID, Bonus, 
ROW_NUMBER() over (order by SalesPersonlD) as [RowCount] 
from Sales.SalesPerson 


×| ا 2 1 1 Microsoft SQL Seryer Management Studio Express‏ ا 


Ela Edl View query Tools Window  Zommunity Help 


= == کر‎ 
: O 1 BÛ | Adventureworks ¬ | fF Execute yî BM So SBS MOF | Es اقا ا ا‎ 


ze lecL SaleszPerszonlD, Bonus, 
ROW HUNBERI] ower [order by BalesPersonlD] as [FRFowLo1 
TrEom Sales. BaleszPerszon 


RLASBETAZ_YWSTISQLERPRESS SL‏ 0ا ا 
El J Catabases‏ 
DO 5+¥sterm Databases‏ 
Adyentureworks‏ ۲ 
LJ Morthwind‏ 


0.00 

A Management 4100.00 
لال0 .لالالا2‎ 
200.00 
SUN. ONU 


EBFON.OU 
SOOO. OO 
390.00 
BODO. ONO 
3200.00 
1.00 

IS0.00 


ماحدث أن استخدمنا هذه الجملة داخل جملة 1 SEL EC٥‏ 

ROW_jNUMBER() over (order by SalesPersonlD) as [RowCount] 
مح وصح الناتيج فى العمود‎ SalesPersonID وهى ببساطة تعنی (قم بعد عدد الصفوف للعائد من الاستعلام السابق مرتبا طبقا ل‎ 
مع ملاحظة هامة جدا اننا وضعنا ں٥٣ سه۸ بين قوسين مربعين [ ] وذلك كون هذه الجملة من الجمل‎ »)R ow Count 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


جinأة PARTITION BY‏ 
تستخدم هذه الجملة بالتو ازی مع الدالة ۸ROW_NUMBERÛ‏ حیٹ یتم تقسیم الاستعلام الناتج من الدالة السابقة الى اجزاء 
لتعود بترتيب متسلسل لكل نتيجة مجزئة على حدا. 


بالطبع نحتاج مثال 
افتح نافذة استعلام جديدة ثم ادخل الکود التالی واضغط ۴٣5‏ 
select CustomerID, TerritoryID ,‏ 
Row_Number() over (Partition by TerritoryID‏ 
order by CustomerID) as [RowCount]‏ 
from Sales.Customer‏ 
Where TerritoryID 1n (1,2) AND‏ 
CustomerID Between 1 and 75‏ 


TerritoryID 


RH Mirrosolt SM Server Management hulo Enprezs 


TOTO ET LICE 


3} f | drearenorke | ا مھ ب سس‎ 4 AEDS 2E | 
xT E ا ل‎  RAUTEER' SILEX Uae 1. aql | ET ت‎ 
1 رك‎ EE: 1 me lect TustaomerTrIDP, TerritoryIN , 

BH I Prcirticrn. Feud sctllstPr kek Bou Eimer over [Fartition bY TerlCitoryIp 

Hl FI Preiiien. Pe seid oCTriET Ty CustomerID] as [Fovtourt] 

BH I Frocrhtion. Percy ticdlelih niy from Sales, Lari opmeEr 

1 I Fradirtem. Fortec here TETFEILGETIR in [l1 AFI 
E Î Freakelieon. Fed Pheke LusEame®r Il Netueen 1 apd T5 


Hi Û Froadikton Feo tF rodi 
EH O Farin. Fe iE re 

H Û Fron, Ferd biha 
Hi Û Frcdijton. Sr pA E 
ee r 
Hl Û Freeborn, Traferonehary; 
HH Û Faron. lrAResare 

EH Î Freier, ê rlatrdêî 

Hi Û Frediktion, #orlrder Rukia? 
HMH SÎ Farha Fredur leda 

HE A Fathering FRrthiaprdr Det, 
HH Û Paheing Father has 
EH Û Fathering. Sheil 

HH I Pahang eder 

Hi Û PFrthegmg veror hdres 
EH Î Farthagirg eer 


HH I Sales CorktartEreadinîad 

A O Se Co agire 
Hl Û ha, Cred 

HH Û Slee Dirmery 

EH Î See. Timer Rabe 

HEH I Fale iha 

HEH O Se Tirhommidiress 

A Û .ةة‎ elin 


r 


wwe. MAERISAEPRESS (O PZ} ADERIeT) plz) Advertsewarka OLS e 


كما بالشکل حدث انقلاب ألعد فی العمود RowCount‏ گ مقابل التغيير الألحادتث للعمود .TerritoryID‏ 
لشرح ما تم فإن الجملة : 


Row_Number() over (Partition by TerritoryID 
order by CustomerID) as [RowCount] 


والتی تم استخدامها کجزء من الجملة S٤1 8٣1‏ تستعمل بالتجانس فيما بين الجمل Row_Number( , over and Partition DY‏ 
لتقوم بهذا التقسيم بناءاً علی شرط ولیکن كما فى مİillî‏ )2 ,1( .Where TerritoryID in‏ 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Serve‏ حسام کمال محمد 


Pattern Matching بئlgقll توافق‎ 


وفيها يتم اختبار حروف من سلسلة نصية ما ان كانت تنتمى الى وإء))هم معينة آم لا. ولتحديد ,)هم معينة تستخدم 
الحروف العادية وكذا الرموز الاستعاضية مثل ( % أو _). لابد وأن تتوافق حروف السلسلة النصية المراد مقارنتها مع ال 
tternهم‏ المحددة مسبقا . تستخدم الجملڵل 11K € , NO1 L1]K۴٤‏ فی اختبار توافق النص مع القالب المحدد مع ملاحظة ان القوالب 
حساسة لحالة الاحر ك Sql Server peڍ .Case Sensitive‏ هذه الرموز الاستعاضية بديلا عن الأحرف فى السلاسل النصية 
المراد مقارنتها. 


ه (% النسبة المئوية ) وهى بديل عن صفر الى أكثر من واحد من الحروف » مثال ايجاد كل العناوين التى تحتوى على 
C# 0‏ بغض النظر عن كيفية وقوع هذه السلسلة من الجملة فى البداية -المنتصف النهاية لا يهم : 
WHERE title LIKE '%C# 2010%'‏ 
تكون النتيجة الرجوع متلا بهذه العناوين : 
““C# 2010: An Introduction,” - “Accelerated C# 2010 “— "Beginning C# 2010 Databases"‏ 


(underscore _ ) e‏ وهی بدیل عن حرف واحد فقط و باستخدامها تکون محدد فی اختيارك للنتائج المرجوة ¢ مثال کا 
ذلك الجملة التالية تعود باسم المؤلف فى قاعدة بيانات والذى يتكون من اربعة حروف تنتهى بالحروف الثلاثة روع : 


SELECT * FROM books db WHERE au_fname LIKE ' ean' 


لتعود لنا النتيجة بالأسماء التالية مثلاً Sean -Kean-Dean ....etc)‏ ) ولو تحایلنا على الاستعلام بوضع أكثر من _ لتعود بأکثر 
من نتیجة مثلا WHERE au_ fname LIKE 'a___'‏ ومعناھا ابحث عن اسم المؤلف الذی یبدا ب (ھ) وینتھی ب (ہ) ومکون من 
Allan Amman‏ 
)square brackets ][ (‏ وفیھا يتم تحديد مجموعة أحرف بديلة عن المراد البحث بها فمثلا [۴-ه] تعنى استعاضة 
الاحرف من ۾ الى ۴ مكان النص المراد البحث عنه وكذا تكون صحية أيضا لو حددنا الحروف يدويا مثل [علءطه] 
متال : 
WHERE au_fname like '[C-K] arsen'‏ 


وتعنى البحث عن اسم المؤلف الذى ينتهى ب عه ويبدأ بحرف ابتداءاً من .Carsen, Darsen, Larsen, Karsen Jia K Û C‏ 


يمكنك استخدا الرمز ^ قبل أى من ١‏ لمجمو عات المحددة وذلك لعدى البحث فى هذا النطاق مثل [۴-^ ] أی لا تستبدل بأى من 


الحروف الموجودة داخل الأقو اس 


أولا استخدام العلامة المئوية % : 
افتح SSMSE‏ افتح نافدة استعلام جديدة كما تعلمت گے السابق » اكتب هذا الاستعلام : 
select Title + ' ' + FirstName + '' + LastName‏ 
as "Person Name"‏ 


from Person.Contact 
where FirstName like 'A%' and Title 1s not null 
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لتكون النتيجة كما بالشكل : 


ll  |mES) 


la Microsoft SQL Server Manag 
File Edit View Query Project Tools Window Community Help 


û aj | AdventureWorks >| ¥ Execute qh و | کی س ی‎ | 7 e E EEL = 8 . 


Object Explorer EKÎ „ NHITEROSE.Adven...- SQLQuery1.sql* | Summary | x 
szelect Title + ' '"' +} FirstName + ' '"' + LastName 


Connect 7 | 4? E 

> aa "Person Name™ 
El ا‎ WHITEROSE (SL Server 9.0.1399 - WhiteRose 

EH Ûd ÛUatabases 

EH Û Security 

EA Û Server Objects 

E A Replication 

EA A Management 

mH OA Notification Services 

SL Server Agent [Agent XP's disabled] 


Erom Person. COnTtaACE 
where FirstName like 'At' and Title is not null 


1 


داعم 


Persan Name 


ET TOE TLE 


Ms. Anna Albright 
Mr. Alberto Baktazar 
Ms. Angela Barbariol 
Mr. Adam Barr 

Ms. Ann Beebe 

Mr. Alexander Berger 
Mr. Alan Brewer 

Mr. Andy Larothers 
Mr. Andrew Cencini 
Mr. Arthory Char 


ن | ]ا 
ج u‏ 


Query executed successfully.‏ ق 


WHITEROSE {4.0 RT)  WhiteRoseHassam (52)  AdventureWorks D0:ODO:0d0 658 rows 


Ln 4 Col 1F ChlF IN: 


ماحدث أن قمنا بتجميع الثلاثة أعمدة Pt1]e FirstName -LastName‏ فی عمود واحد تحت مسمی ع٥×‏ ٥ی٥٥‏ باستخدام 
الجملة ٠‏ 
select Title + '' + FirstName + '' + LastName‏ 
as "Person Name"‏ 
from Person.Contact‏ 


WHERE FirstName like 'A%' and Title 1s not null 
وتعنى ان يكون الاسم الأول يبدا بالحرف ۸ لاى عدد من الحروف يعقبه‎ 


مثال باستخدام 
اكتب الجملة التالية فى نافذة استعلام جديدة : 
select Title + '' + FirstName + ' ' + LastName‏ 
as "Person Name"‏ 
from Person.Contact‏ 
where FirstName like 'B_ a' and Title 1s not null‏ 


لتكون النتيجة كما بالشكل: 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


BUTE SERE EEE 
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as "Person Name™ 
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2 I1 ۴ ي‎ Query executed successfully. WWHITEROSE {3.0 RIM) WhiteRose Hossam (52)  AdventureWorks O0D:OO:00 4rows 


Ready Ln 4 Lol 33 Lh 33 IN: 


:(Square Bracket) [ ] مIدختساب مٿال‎ 
٠ افتح نافدة استعلام جديدة واكتب الجملة التالية‎ 
select Title + '' + FirstName + ' ' + LastName 
as "Person Name" 


from Person.Contact 
where FirstName like '[A-I]_ ' and Title 1s not null 


Fe Edê Vie ey Peed Teck Window Commaney Hep 


J New Qer | Bı | È Ia lz ga a ض‎ a 2ض‎ 
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برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


ماحدث كما بالسابق مع اختلاف الاستعاضة هذه المرة فالبحث عن الاسم الاول المكون من ثلاثة أحرف والذى ببتدئ بحرف 
ضمن مجمو عة الحروف من ۸ الی 1 ویبنتهی بای حرفين. 


:(Square Bracket and Caret) [^] مIدختwlب‎ Jاٽم‎ 
٠ افتح نافذة استعلام جديدة واكتب الجملة التالية‎ 
select Title + '' + FirstName + '' + LastName 
as "Person Name" 
from Person.Contact 
where FirstName like '_[^1][a]__' and Title 1s not null 


لتکون النتيجة گاالی. 
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Aggregate Functions gıaجتlا‎ JIود‎ 

تحتوى لغة 5Q1‏ على دوال ضمنية لعمل حصر او تجميع لمحتوى الأعمدة من قيم.وتطبق على العديد من الصفوف لتعود بقيمة 
واحدة. على سبيل المثال يّمكنك استخدام أحد هذه الدوال فى حساب متوسط سعر سلعة ما فى عمود.وكذا يُمكنك حساب أقل أو 
أكبر سعر بالطبع. من دوا التجميع التى سنتعامJ‏ معا .AVG,MAX,MIN,SUM,COUNT‏ 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


مثال على ذلك 

تطبیق ماذکرناہ بأعلى كمال على حساب متوسط وأقل وأکبر ومجموع سعر وحدة (٤۴c٤ہ¡ہا)‏ لکل أمر بیع (17إdeإ40ءاھ5S)‏ من 
انجدJg .SalesOrderDetai]‏ 

افتح نافدة استعلام جدید وادخل هذا الکود واضغط ع)ںcعم×ع‏ او ۳5 لاتنفیذ ٠‏ 


select SalesOrderID,min(UnıtPrice)as "Mın", 
max(UnıitPrice) as "Max",Sum(UnıtPrice) as "Sum", 
Avg(UnıtPrice)as "Avg" 

from Sales.SalesOrderDetail 

where SalesOrderID between 43659 and 43663 
group by SalesOrderID 


أتشاهد كما با شك ٤‏ 


۹ Microsoft 5L S5eryer "Management Studio Express 


Eile Edit  Yiem  ouery Tools Winda Lommunitw Help 
ظط‎ 
: 7 a 4 | ûdYventureyorks 2 ¥ Execute 2 | لر“‎ 4 4 E" 
Gbject Explorer ÛORCASBETAZ_Y¥...LQuery1.sql* 
1 J m 3 T zeElect SalesûrderID,minlUnitPrice}] as "Hin", 

. د کر‎ 1 1 FF FF 1 1 FF FF 
I lj CEZASBETAZ_YSTSISQLEXPRES a Sum {UnitPrice)]j as "Sum", 

El Gl Catabases Air [ UnilLPEiIiCE} a3 ا‎ 

I 35¥stem Databases Tro Sales. SalEeszUFAEFDETLaA1 l1 


۳ ET e whieEFTE SaleszUrderE lID between 436053 and 43 b3 
وا‎ Northwind JrFOUp by Salesirqder ID 
LD Security | 
O Server Objects 
CO Feplication 
LO Management 


i Results | Lg Messages | 
| SalesUrderl D 
| 1.13 2133.194 143237118 1133426 
1 413.4583 | 874794 129429 BA4FI2B4 
3| 43661 3. 13B 2133.934 14236738 5 
4| 43B 178.5808 | 214B. 12955.481 BBB. 


3 | 430B3 413.4503 413.4081 4303 413.4003 


لشرح ماحدث فإننا استخدمنا الدوال ×N1N‏ و ×۸" وذلك لحساب أصغر وأكبر قيمة للسعر وكذا استخدام الدالتين S05‏ و 
6 لحساب المجموع ومتوسط القيمة على الترتيب 
min(UnıtPrice) as "Min",‏ 
max(UnıitPrice) as "Max",‏ 
Sum(UnitPrice) as "Sum",‏ 
Avg(UnitPrice)as "Avg"‏ 


وقمنا باستخدام الدالة 8۷ ۲ا G۸0‏ لترتيب العناصر حسب 1Dإءلإ0ءء]1ه؟.‏ من النتائج المعروضة نري أن أقل قيمة للسعر 
بالنسبة ل 1 ل0 هی ٥,۱۸٦١‏ وأن أقصى قيمة هی ۲۰۳۹,۹۹٤‏ وان متوسط السعر هو ۱٠۹۳,٦٤٩١‏ وإجمالى سعر 
الوحدات هو .۱٤۳۲۳,۷۱۱۸‏ 


جرب الدالة N1‏ ا١٥0٥‏ : 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


لنقم بعد السجلات الخاصة بالجدوال )ء01)a٥C.ہPers0.‏ 
افتح نافذة استعلام جديدة كما هو معتاد وأدخل الکود التالی ثم ۴5: 


Select count(*) as "Total Records" from Person.Contact 
Select count(TItle)as "Not Null Titles" from Person.Contact 


لاف كما بالصر رة اال 
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لفهم ماحدث فإن الدالة C00 N1‏ لها استخدامات عديدة تتوقف على البرامتر إع)ء هرهم المضاف اليها › فمثلا ()1 N‏ °01 
تعنی حصر جمیع السجلات الممكنة کما بالمثال أعلی وهی ۱۹۹۷۲ سجل من الجدول اءھ),0٤.0إء۲.‏ 

أما لو استخدمت اسم العمود كبرامتر فإن القيم التى ستعود هى القيم التى لاتحوي N1011‏ ففى المتال قمنا بوضع العمود ا)1 
كابرامتر للدالة COUNT‏ ومع أن عدد السجلات الحفیقی فی المثال هو ۱۹۹۷۲ سجل إلا أن ناتج هذه العملية هو ٠٠١۹‏ سجل 
فقط ! وهو مايعنى تجاهل السجلات ذات القيمة إاا×. 


دوال الوقت وتر DATETIME Functions‏ 

على الرغم من أن الن وع N٤‏ معرف ضمنيا فى لغة 1 القياسية مشتملاً أيضا على مكوناته 
YEAR ,|MONTH, DAY, HOUR,MINUTE,SECOND‏ » إلا أنها لاتوضح كيفية تعامل نظام إدارة قواعد البيانات )586M5S(‏ 
معه فيما يعنى أن كل 58S‏ له طريقته فى التعامل مع هذا النوع وهذه الدوال. 


جرب التعامل مع دوال الوقت والتاریخ فى ا1-8Q‏ 
افتح نافذة استعلام جديد وأآدخل هذا الكو د تم اضغط عاExecu‏ : 
select‏ 
current_timestamp'standard datetime’,‏ 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


getdate()' Transact-SQL datetime’, 
datepart(year, getdate())'datepart year’, 
year(getdate())'year function’, 
datepart(hour, getdate())' hour’ 


FB E so gî Tk Fra Gomi Hap 
ف ع ل ف اق لا ع | را اسب س لے‎ 
1i E8 r hiper gaol a ؟‎ Exogia qy” ا‎ i وة 2 و‎ r | | 2 E F۴ 


|W SOLES, PUApaery 1 aql* | mmary ت‎ 4 | 


| A mY soked axceluhy POSSAMISGLEPRESS 0 P3) HOSSAMFmal B2)  Avermrewurks DO0:0 |1 rows 


تعودنا حینما نری جملة 9٤1٤٣۲‏ أن نلحقها ب ۴۸0۷ لكن هذا فى الصيغة القياسية » أما فى مثالنا هذا فإن أول سطرين من 
الاستعلام مسئولان عن جلب التاريخ والوقت 
select‏ 
current_timestamp'standard datetime’,‏ 
getdate()'Transact-SQL datetime’,‏ 


السطر الأول يستخدم الجملة CURRENT_TIMEST ANP‏ وهی جزء من لغة $1 القياسية › اما الدالة 6٤12۸1۲٤0‏ فھیى 
جزة من عة 1 1-8Q‏ فكلاهما يعطى نفس الناتج. 
فى السطرين التاليين 
datepart(year, getdate()) 'datepart year’,‏ 
year(getdate()) 'year function’,‏ 


فان الدالة D۸1٤ P۸81‏ تعمل علی تقسیم التاريخ کا حسب المعامل المضاف لها مثل حالتنا هذه ۲8۸ » أما الدالة 
R۸‏ فهى تجلب السنة مباشرة من تاريخ معين وفى حالتنا هنا حصانا على معامل التاريخ باستخدام الدالة .6٤1۲0۸1۲۴0(‏ 


فى السطر الأخير حصلنا على الساعة الحالية (لاحظ ان 1-Q1‏ لايوفر دالة مستقلة للساعة مثل الدالة 8۸8 )Y‏ فقمنا باستخدام 


الدالة مقسمة التار يخ ٤۲0۸1٤0‏ مع المعامل H010‏ للحصول على الساعة 
datepart(hour, getdate())' hour’‏ 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


تستطيع تنسيق واستجلاب الوقت والتاريخ والعديد من المزايا الأخرى بعدة طرق › فيمكنك زيادة الوقت والانقاص منه أياً ما 
كان نوع 08S‏ الذى تعمل عليه » لكن انتبه ! لأنك ستجد أصعب نوع بيانات ستعمل عليه هو الوقت والتاريخ وستضطر 
لتتعامل بحرفيه مع هذه الدوال البسيطة المدرجة ضمن 1-۹Q1‏ او ماشابهه من لغات. 


تنویه 
تأکد عندما تستخدم بياناتمن نوع 0۸1۴11۷۴ ان تدخله بطريقة معينة مثل 3/21/2003 فهذه هى أنسب طريقة لإخبار 58١8‏ 
ان هذا السجل یحوی بيانات من الن وع ۸٤ ]M٤‏ لكن قبل هذا عليك قراءة تعليمات ۶1 الخاصة بالنظام الذى تعمل عليه. 


J015 فهم‎ 

فى أغلب الأحيان قد تضر لعمل استعلام من أكثر من جدول › ولحل هذه المشكلة فإنك حتماً ستضطر لاستخدام جملة ١[ا0[.‏ 
لفهم ماهية [0۲N‏ فإن دورها يقوم على الاستعلام عن بيانات من جدولين أو أكثر (ولا يلتزم التمايز) ومطابقة الحقول بكل منهم 
هناك انواع كثيرة من وممز والتى تتحد فى فكرة أنها ذات عمليات ثنائية حتى ولو كانت على نفس الجدول (كما سترى). 
عمليات ال ومزمز مزعجة وأحيانا تبدو معقدة بعض الشئ لكن لاتقلق سأحاول تبسيط الأمر بما يسر الله لى. 

سنستخدم فى عمليات ال ومزمز قاعدة البيانات الشهيرة لہس ط۲إه× بالطبع انت تعلم كيف تحصل عليها كما سترى فى الملحق. 


Inner Joins 
¢ وهی أشهر أنواع ا ورهز اذ تقوم بإعادة صف واحد طبقاً لما حددته فى استعلامك وغالباً المشترك بين جدولين كما فى الشكل‎ 
:)هام۸ یصلح نظریا فى خصائص جملة مزمز مثل ( > أو >( إلا أن العامل‎ ٥ ٣۵1 علی الرغم من ان ای عامل ارتباط ماهإمم0‎ 
.natural joins هو الأكثر استخداما و هذا النوع من ەز يسمی‎ )=( 
تتكون جملة مزمز من التالى:-‎ 
select 
<select list> 
from 
left-table INNER JOIN rıight-table 
ON 
<jJoıin specificatlon> 


Table A Table B 


سالفا اخبرتکم أن inەز‏ عملیة ثنائیة و0ناaإ0pe‏ ryھہBi‏ فیما یعنی کما تعلمنا من الرياضيات أنها تحتاج إلى طرف أيمن وطرف 
أيسر ولهذا نر ى الجملة ٥1ط‏ ۾†-right NNER JON‏ tab1e-e۴ا‏ ولا يعنى هذا لزاما ان يكون أحد الطرفين جدول خالص › إنما 
قد یکون ای شئ مستخلص من استعلام ما او حتی جدول ناتج من عملیة ہ1ه‌ز اخری. 

الكلمة ×0 هى التى تحدد متطلبات جملة مزمز يعنى باختصار أى شرط يتحقق بالجملة .WHER#E‏ 


جرب هذا المثال لتقريب الصورة 
سنقوم بطلب قائمة الطلبيات بمعنى رقم ال [D‏ للعميل الذى طلب ..و مهه اوه!] للموظفين وعءرهام مء القائمين على ذلك. 
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افتح نافدة استعلام جديدة (تذدکر أننا نعمل ا قاعدة البيانات Northw1nd‏ ( وأدخل هذا الاستعلام واضغط E5‏ 


select 

orders.order1d, 

orders.customeri1d, 

employees.lastname 

from 

orders Inner Jo1n employees 

on 

orders.employee1ld = employees.employee1ld 


لاف كما بالصور :اة 


ال ست سس س تت ر | س س س | ا | ا ت 
ا gaa‏ | ا ا ا Northwind + ٣ Execute „y’” FF‏ 4 1 


ODE { Explorer S4 3  HOSSAMISQLEX...LQuery1.sql* 
+ Sm 3 T select 
1 lf HO55AMISALEXPRESS (SQL Server 9,0,4035 - HC REE BESE, 
E1 Ê Databases OEAeErFE .CUSTOMEE iA, 
a a4stern Databases Emp lOYFEE3 . la2TthalE 
lJ Adyentureworks From 
J Morthmind orders inner join Employees 
L_J Security on 
I Server Objects OEFAErF2.EmployeEEid = Emp lOyEES . Emp lDyEE i2 
lA Replication 
J Management 


i Results Es Messages 


arderld | custamerld j lastname 
YINE T Buchanan 
TUMSFE Suparma 
Hé RF Peacock 
YILTE LeYerling 
SUIPRD Peacock 
HêlĞR Leverling 
LHOPS Buchanan 
RILSL Dodsworth 
WE LLI Leverling 
H۱11 ,ك‎ Peacock 
11 | 028 ERNSH Dawolin 


4 ا*‎ 2 HuErY executed successfully, HOSSAMISQLEXPRESS {4,0 5P3) Hossamimal 5Z) Northwind u: 0:01 ج‎ FOIS 


Ready Ln 8 ol 41 Lh 41 INS 


هل لاحظت معى إختلاف الاستعلام مع جملة S1٤٣1‏ هذه المرة ؟! ...بالتأكيد اختلف والسبب فى اننا نستعلم عن اكثر من 
عمود من جدولین مختلفين وبالتالى كان لابد من تمايز كل عمود بجدوله باستخدام الفاصلة (.) مع اسم الجدول يسبقها وهذا 
متعارف علیه باسم إزالة الالتباس او disambiguation‏ ولهذا لايجد نظام ادارة قو اعد البيانات صعو ية أو مشكلة گے معرفة 
المطلوب منه › هذا الاجراء أيضاً لا يلزم أن یکون کل عمو د بجدول منفصل ..إنما يمكنك استخدامه فی أى استعلام عاد کل 
ولو كان من نفس الجدول. 
جملة ۴۳۸0M‏ هنا استخدمت اسم الجدولين متوسطا بنوع «زەز والتى ف" llتi| inner join lik‏ 
from‏ 

orders Inner Jo1n employees 
Fore1gn Key بالمفتاح الخار جي‎ Employees للجدول‎ (Employeeld ) P.K وهی توضح ضابط ربط المفتاح الأساسي‎ 
. Orders للجدوڵ‎ )Empاoyeeld)‎ 
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on 
orders.employee1ld = employees.employee1ld 


لاحظنا ان ناتج الاستعلام السايق مكون من ثلاثة أعمدة Oredr1D , CustomerID , LastName‏ و ھی ناتج الصفوف فی 
الجدولين التى يشترك فيها العمود ٥1ءءرهام E"‏ نفس القيمة وبالتالى فإن اى قيمة فى اى صف لا تتوافر فيها هذه الشروط يتم 
استبعادها. 


ملحوظة: هل انتبهت الى ان 12ءءرهام ص لم برج فى جملة S51 ٤8٣1_‏ مع أن مدار عمل مامز فى هذا المثال عليه ؟// 


نفس المثال لکù Correlation name ga‏ 
افتح نافذة استعلام جديدة (لازلنا على قاعدة مس ط)اهN)‏ ادخل هذا الاستعلام ڌÛ۾ۃ Execute‏ 


select 

o.orderı1d, 

o.customer1d, 

e.lastname 

from 

orders o inner Join employees € 
on 

o.employee1ld = e.employee1id 


لترى النتيجة كما بالصورة 
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هل لاحظت أن النتيجة هى هى لم تتبدل ؟! 

قمنا باستخدام ما يسمی relation name‏ لكل جدول » وهى بمثابة اشارة مرجعية ع٥,ع]ء]م]‏ كما فى البرمجة العادية 
(بالطبع أسمعك تقول أن هذا ماهو إلا وموهزإه لاسم العمود› صحیح أن الطريقة مشابهه إلا انه ليس كذلك حيث ان هذه الطريقة 
تحل محل الجدول فعليا ولیس مجرد عنذونة للاإسم کو aliases‏ (“ فبامكانك الان أن تشیر الى sمل٥‏ 0 ب ہ والی 
Employees‏ ب م وهذا أسهل کثیرا أثناء كتابتك للاإستعلام بدلا من استخدام الإسم مطولا. 
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مثال آخر مع ثلاث جداول 
افتح نافدة استعلام جديدة (لازلنا غل قاعدة (Northwind‏ ادخل هذا الاستعلام تم Execute‏ 
select‏ 
o.orderid OrderID,‏ 
c.companyname CustomerName,‏ 
e.lastname Employee‏ 
from‏ 
orders o 1nner Join employees e‏ 
on o.employeeid = e.employeeid‏ 
inner Join customers C‏ 
on o.customerild = c.customer1ld‏ 


لترى كما بالصورة التالية 
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اختلافا عن المثال السابق قمنا باستبدال 1DإمeہہtوںC‏ من الجدول وrمل0r‏ ب CompanyName‏ من الجدول Customers‏ فی 


.SELECT ةlnج‎ 
select 
o.order1id OrderID, 
c.companyname CustomerName, 
e.lastname Employee 


جدول عن ال Joın‏ ك يتم ادخاله فی ال Joın‏ : الثانية مع الجدول e e‏ دانسا فی كتابتك لأى PE‏ أن 
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يكون منسقا كى يكون مقرو ءا لهذا قسمنا الإستعلام إلى ثلاثة أسطر .يُمكنك أن تستخدم الأقواس فى حالة الاستعلام الكبير أو 

المشترك كما فى حالتنا هنا اكثر من مەز إ٥«م ٠‏ (بما أن الناتج جدول يمكنك إدخاله فى عمصهدم «ەa)1اءءإهء‏ لكن هذا الاستعلام 
سيكون متشابك وسيربكك ©). 

from 
orders o 1nner Join employees e 
on o.employeeid = e.employeeid 
inner Join customers C 
on o.customer1ld = c.customerld 


لاحظ ان عملية المقارنة ستتم بين الجداول الثلاثة لذا فإن كل الصفوف الخاصة ب یإملإ0 تم عمل عم نطءاھص لھا مع بالجدولين 
الاخرين. 

من الطبيعى ان نتسائل عن كيفية تلبية نظام قواعد إدارة قواعد البيانات لهذه العمليات »الأمر يكمن فى أن ءممز جزء لايتجزاأً 
من عمليات قواعد البيانات العلائقية حيث تلجأ إلى تحسين منصت)مه طريقة التعامل مع أكثر من جدول مع مراعاة انه كلما 
استخدمت ورهز أقل كلما ازدادت كفاءة استعلامك وهذا يعود لجودة تصميمك لقاعدة البيانات وخبرتك فى الاختصار على نفسك 
برمجيا.لكن ماذا عن الجداول التى لا تحوى صفوف متمائلة ؟! هذا هو التالى .. 


Outer Joins 


تعمل ءاهز مه على إرجاع كل الصفوف من (على الأقل) واحدِ من الجداول المشتركة فى هذه العملية حتى ولو كانت هذه 
الجداول غير متماثلة ءاه ء٥‏ 10. هناك تثلاثة أنو اع من sمنەز outer‏ اولھا : right outer join : lgilûs left outer join‏ 
وثالثھا : وذەز f11 outer‏ . إن tطعنا‏ ,fه]ا‏ ماهى إلا إشارة إلى جهة ال لمهإممه من معامل ال مزمز . 

النوع الأول outer join‏ ها فإن كل صفوف الجدول الأيسر من ١1ز‏ ستعود قيمتها فى حالة أنها تطابق الصفوف فى الجدول 
الأيمن من صiەز.النوع‏ الثانى right outer join‏ عکسه تمام فكل الصفوف للجدول الأيمن من nہاەز‏ ستعود قیمتها إذا ما طابقت 
صفوف الجدول الأيسر من ہزه‌ز.النو ع الثالث نەز outer‏ 11 يعود بكل صفوف الجداول على أيمن وأيسر .Jo1n‏ 


مهلا ! كل هذا رائع لكن أين الفائدة ؟! 

هناك حالات مثل العلاقة ل1نطع - ٤مءإه٥‏ مابين الجداول على الر غم من وجود التكامل المر جعي فیما Referential pi‏ 
Integrity‏ بعض صفوف الجداول الأباء Parents‏ لا علاقة لها بصفوف الجداول الأبناء Childs‏ مچ احتمالية شغل القيمة [إںم 
گن أحد صفوفھا والتی بمثابة .۳ للجدول الأب ولهذا إيٺيحدmڌ matching‏ . لکی نوضح بمتال فان البيانات الخاصة بكلِ من 
الجداول Orders - Employees‏ تحتاج الى بعض الإضافات. 

ا تضبف بيانات مو ظف employee‏ فانك ستضبف ا جدیداً للجدول Employees‏ والدى لاير تبط بعلاقة مع صفو ف جدول 
ءهل. لتبسيط الأمر كل ماعليك هو إضافة البيانات الجديدة للأعمدة التى لاتقبل 1إuم.‏ 


جرب إضافة موظف جديد 
افتح نأفذة استعلام جديدة تم أدخل التالي واضغط Execute‏ 


insert into employees 


( 


firstname, 
lastname 


values (Hossam', 'Kamal') 
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ليكون الناتج كما بالصورة التالية 
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الأمر بسيط فقط جملة NSR‏ وتعيين العمودين المراد إضافة بيانات لهما مع العلم أن llعمgڌ EmployeeID‏ تضاف قيمته 
تلقائيا لأنه سبق تعريفه أثناء تصميم الجدول على أنه 1D٤N 117۲١‏ وباقى الأعمدة تسمح بالقيمة N11‏ فلا يهم إضافة قيم لها . 
لديك الأن بعد هذا الاستعلام موظف جدید باسم Hossam Kama‏ والذدى لم يتلق أُی ore‏ بعد.لنفتر ض الان أننا نريد قائمة 
بالطلبيات orders‏ التی تمت لكل الموظفين على شريطة جلب كافة ال employees‏ حتی من لم بجر ی أُی طلبية هذا هو المتال 
التالى. 
جرب LEFT OUTER JOIN‏ بد تعدJı‏ جڍJg EMPLOYEES‏ 
افتح نافذة استعلام جديدة ثم أدخل الاستعلام التالی و ۴5 
select‏ 
e.firstname,‏ 
e.lastname,‏ 
o.orderid‏ 
from‏ 
employees e left outer Join orders O‏ 
on e.employeeid = o.employeeid‏ 
order by 2, 1‏ 
لترى النتيجة كما بالصورة التالية 
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إذا ماجربت المثال السابق باستخدام مزه[ إممم!] فلن تجد الموظف احوصهK‏ صهءءم1 ضمن الناتج (جرب هذا بنفسك). 

لاحظ فی الاستعلام ان 8۷ 0۸5۴٤8‏ والتی استخدمت لترتیب الناتج على حسب ءصNa‏ یھ , Nm‏ ۲ی۴۲ والتى استخدمنا 
فيها ترتيب الأعمدة وليس اسمها (2, 1) وهى طريقة جيدة لكتابة الاستعلام فى حالة ما إن كان العمود ناتج عن دوال التجميع 
مثلاً مثل ۷ 40.لاحظ فراغ قيمة 10ء ل0 عند الموظف الجديد كما فى الصورة. 

أماذا 5 استخدمنا ہزەز 1ft outer‏ ولس right‏ ؟! الإجابة بديهية إذ يمكنك فعلها فقط بالتبديل مابين أسماء الجداول من الجهة 
اليسرى اس اليمنى والعكس وكذلك ال Correlation names‏ ..وسیكون الناتج واحد أيضا (جربها بنفسك). 


Other Joins 

أردت عدم التلميح إلى outer Join‏ 1 لوجود انواع أخرى مثل زە[ ونر و inە[ Css‏ وھذە الأنواع قلما تستخدہ وخارج 
نطاق الكتاب a‏ أحب شرح الأشياء النادر حدوتها إنما أفضل اكتاسبها بالخبرة العملية وقت الحاجة) لكن عموما 

:F ull Outer Join‏ یعید يعيد لك كافة الصفوف فى الجدولين معا اليمين واليسار حتى ولو لم يُوجد صفوف مرتبطة معا. 

:U nion Join‏ يقوم بانشاء جدول مستقل عن الجدولين وجمع البيانات فى كلا الجدولين شريطة اتحادهما فى عدد الأعمدة وكذا 
امكانية قبول نوع بیانات عمود محل الآخر ا اذا کان معرفاً String‏ أو Memo‏ یمکن احتواء هم .و یكون الاستعلام کالتالی: 


Select * from table1 union all 
Select * from table2 
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:Cross Join‏ وهو يدمج كافة الصفوف من الجدولين وينتج عنه جدول يحوى كافة الأعمدة وصفوف بحاصل الضرب 
الديكارتي (مصطلح رياضي مشهور) للتوضيح نفترض أن عندنا جدول به خمسة اعمدة وخمسة صفوف وجدول آخر به ثلاثة 
أعمدة وعشرة صفوف إذا ماقمنا بعمل مه[ ووهإ٥‏ بينهما فإن الناتج جدول ثالث به خمسة عشر صف وتمانية أعمدة (صدقنى 
لھا استعمال لکن خار ج تغطيتنا © ). 


خاتمة الفصل 

فى هذا الفصل تعلمنا كيفية كتابة استعلامات فى ع٤S؟55MN‏ واستخدمنا مزايا كثيرة فى ا5۵ . استعملنا 
Aggregate Functions‏ تعاملنا مع دوال الوفت والتاریخ .9هھمنا کیفیة تطبیقی 8۷ 6۸0۷۴ مع أی استعلام 
.استعمالنا ال ءامل وعرفنا الفروق بينها . كل هذا وأكثر تعلمناه وكان الفغرض أيضا تنشيطا لكى تكتب 
بنقفسك حتى وإن استصعبت بعض الاستعلامات فانك حتما استمتعت بكتابتها وروية الناتج بنفسك. 


C# 2010 and MSSQL Servef 2008 برمجة قواعد البيانات باستخدام‎ 


الفصل الثالث 


التعامل مح بيانات فاعده البيانات Manipulating Database Data‏ 


حسام كمال محمد 
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سنتعلم فى هذا الفصل التالي: 


حان الأن وقت التعديل فى البيانات الداخلية بعد إدخالها عن طريق العمليات Insert , Update , Delete‏ 
استرجاع البيانات 

SELECT INTO ilجلا استخدام‎ 

Inserting data ٽlنlيبll‎ Jاخادإ‎ 

Updating data تاlنlيبلا تحديث‎ 

Deleting data ٽlنlيبll حذفزف‎ 
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إسترجاع البيانات 
تعلمنا استرجاع البيانات بصورته البسيطة عن طريق استخدام جملة $۴1,٤٣١‏ فى الفصل السابق.فكما نعرف ان البيانات 
تخزن فی صفوف وسو داخل جداول وم1طه] وهذہ الصفوف بدور ھا تحوی أعمدة وممرں‌[مء ولکی نبسط الأمر فإن الإستعلام 
يتکون من جزئين رئيسیین: | | 

جملة S٤1 ٤٣1‏ تخصص |أى من الاأعمدة سوف يرجع بالبيانات. 

جملة ۴۸0۷ تحدد ای جدول / جداول یحوی هذه البيانات. 


EEG N I O LE E AY‏ يعنى أنك لابد ان تفعل ذلك أثناء 
ا عة 4 اا ل ار SENSITIVE‏ الكلمات المحفو ظة words‏ م تکتب 


EE RE ماشئت‎ leaw SELECT ll query ET ET ولا ينتج عنها‎ 
, الكتاب‎ 


استخدم الکلمتین S51 6٣1 , ۴8۸0M‏ لتجلب البيانات من أى جدول كما بصورتهم البسيطة فى التالي: 
Select * from <table name>‏ 


كما تعلم فإن (*) )ونرم)وه تعنى كل الأعمدة فى الجدول . 
إجراء استعلام بسيط 
افتح SS M5۴‏ تأكد أن قاعدة البيانات التى تعمل عليها هى لس طاإه× أدخل الإستعلام التالي ثم ع)ںم×Ex‏ 


Select * from employees 


لترى النتيجة كما بالشكل 
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ماحدث انت تعرفه › ببساطة أنت طلبت الحصول على كافة أعمدة جدول الموظفین ءءءرم1م ۴E‏ وكان ذلك 1 ! ولتتأكد من أناك 
حصلت على كافة الأعمدة بُمكناك أن تتصفح الجدول الناتج بالإزاحة ناحية اليمين لتراهم جميعاً. 
هناك ملحوظة يرجى التنبه لها .. فحينما تجرى استعلاماً ما تأكد من حصر المطلوب على أعمدتك فقط وذلك حتى لاثضيع 
الموارد وع ںموهR‏ بلا فائدة » ولعمل ذلك اتبع ال : 
افتح نافذة استعلام جديدة رإءںQ‏ سه" وأدخل الاستعلام التالي ثم ۴5.. 
Select employee1d, firstname, lastname‏ 
from employees‏ 


هذا الاستعلام يُرجع لك ثلاذة عمدة قط ھآ”ى .Employees Jgڏجll ja EmployeeID,FirstName, LastName‏ 
وتشاهد النتيجة كما بالشكل .. 
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WHERE ارط‎ el 
يقوم بتحديد مرادك تماماً من الاستعلام عن طريق شروط مابين منطقية أو‎ ۷18۸۴٤ السابق أن الشرط‎ pF 
كما رأينا مُسبقا.‎ Patterns مقارنة بین قو الب‎ 
من التالي..‎ W1٤۴ فی أبسط صوره يتكون الشرط‎ 
WHERE <column1> <operator> <column2 / Value> 
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<إە†هإممه> يحتمل إحدى عوامل المقارنة التالية (= و < > و > و< على سبيل المتال) ووجه المقارنة إما عمود آخر أو قيمة 
.value‏ 

لتحسين الاستعلام السابق سiستخدم ٤ WHERE‏ 

أضف السطر التالى للإستعلام السابق (أرجوا أن تكون لازلت فاتحأً SSM8#٤‏ ): 


Where country = 'USA' 
.. لترى النتيجة كما بالشكل‎ ۳×٥٥ ں{٤م ثم اضغط‎ 


RT TTT TTC OLEN 
: f g2 | nortiwend | ا2 ا 1 وت 17 | ج | ی 2ے اھ ب معت ؟‎ 


E1 ر‎ mH 2 TT ُ He lect Emp logeeid, Tice tnneae, latrines 


from employee 
where country =' ISA '| 


۰ + 


نتبجة فانتبه , 


ماحدث واضح فجملة ءء س حددت لنا المطلوب بدقة وهم الموظفين أصحاب البلد 54٠‏ وتم لنا المراد برجوع جدول به 
أسماء المو ظفين وكذا ال ر] الخاص بهم. 


WHERE طرأll‎ ga Comparison Operators ةiرlقnئll‎ Jماوع استخدام‎ 
: لاحظ الجدول التالي‎ 
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إذا عملت من قبل على 1مك اكن مع منصات أخرى غير مايكروسوفت فانتبه لأن ليس كل هذه المعاملات فى الجدول موجودة 
فی آی اصدار آخر إلا فی @؟-7 والتی نلتزم بال ×ى]”ر؟ الخاص بها طوال الكتاب. ٍ 

بالإضافة لهذه المُعاملات يوجد أيضا المُعامل ع[ والذي تطرقنا له سابقا على عجالة (سنناقشه لاحقا فى الفصل التالي) لكن 
لا مانع من جدول يحتوي بعض التفاصيل: 


هذا المعامل بدوره يحتوى بعض ال ءلإةءلW¡1‏ والتى تأوضحها فى الجدول التالى: 


فى بعض الأحيان تكون القيمة فى بعض الصفوف غير معلومة وأنت تحتاجها فى استعلامك.و هناك أيضاً أعمدة تحوى القيمة 
11م نتيجة عدم اسناد أى بيانات لها (ليس معنى ان قيمة ما فى عمود حصفر أنه 11 »)N.1‏ ولعمل إستعلام على هذه الأعمدة 
نحتاج الشرط ]N.01[ N.11‏ 15 انظر الجدول التالي: 


ستقول لى من الممكن الاستغناء عن هذين الشرطين باستخدام أحد المعاملات السابقة مثل = أو!.. 
وهذا خطاً شائع فمثلاً اكتب هذا الاستعلام 


SELECT * FROM employees WHERE Region = NULL 
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اضغط ۴5 لترى النتيجة وقد خرجت لك بجدول فار غ يحوى أسماء الأعمدة فقط ...لكن اذا استبدلنا = بالشرط $] ستر النتيجة 
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ولإجراء استعلام اختيار قيمة تقع فى ععم هع معين نستخدم الشرط N×٤غ 81W‏ و 1N‏ ولتوضيع عملهما انظر الجدول التالي.. 
8 صح ٤‏ 


Combining Predicates طbgرأll دمج‎ 


فى بعض الأحيان قد تحتاج إلى شروط متداخلة لتحقيق استعلامك تماماً ولفلترة بياناتك › يُمكنك هذا باستخدام المُعاملات 
المنطقية وإماهإءم0 a1ءعه‏ ولتوضيح ذلك انظر الجدول التالي: 
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من المُستحسن استخدامك الأقواس حتى يسهل قراءة استعلامك ..وفى بعض الاستعلامات المتقدمة يكون حتم عليك هذا. 


فرز llبيlنlت Sorting Data‏ 
بعد قيامك بفلترة البيانات التى تريدهاء بامكانك فرز البيانات قياساً على احد الأعمدة او اكثر من عمود صعوداً أو هبوطاً› 
فالنتائج العادية التى تحصل عليها من الجدول تكون فى الغالب غير مرتبة وغير معلوم طريقة ترتيبها. ولكى تجبر النتائج على 
ترتيب معين فإننا نستخدم الجملة 8 0۸5۴8 بهذا الشكل : 

ORDER BY <column> [ASC | DESC] {, n} 


يعبر الشرط <مصںاهء> عن العمود الذي سيتم الترتيب حسب ما به من قيمة.والعبارة ([ہ ,]) تعنی تخصيص أی رقم من 
الأعمدة سيّطبق عليه الشرط مفصولاً بالفاصلة مثل [2,5,7,15) وبالطبع سيتم الترتيب صعوداً أو هبوطاً طبقاً للشرطين 
.ASCIDESC‏ 
ASC: Ascending (1, 2, 3, 4, and so on ®‏ 
DESC: Descending (10, 9, 8, 7, and so on ®‏ 
ولك أن تعلم أنه فى حالة نسيانك وضع شرط لترتيب الاستعلام الناتج فإن القيمة الافتراضية ستكون تصاعدياً ۸8€ . 
المثال التالى هو الشكل العام لهذا النوع من الاستعلامات: 
SELECT <column>‏ 
FROM <table>‏ 
WHERE <predicate>‏ 
ORDER BY <column> ASC | DESC‏ 
ستقوم الآن بتطبيق القاعدة العامة بأعلى على مثال حقيقي » ففى هذا المثال سنقوم بالتالي: 
ه استرجاع قيمة الطلبيات وله التى تمت بواسطة الموظف رقم ° (5 ممر0امصه) . 
استرجاع الطلبيات المباعة الى عcمھإ۴‏ أو Brazi]‏ 
6 إظهار الأعمدة OrederID , EmployeelD ,CustomerlD, OrderDate, SshipCountry‏ . 
٠‏ سيتم الفرز طبقاً للدولة المباع لها وتاريخ البيع. 


هل ببدو الأمر معقداً ؟ 2 لا تيأس فقط حاول. 
افتح نافذة استعلام جديدة ذ” SQL Server Management Studio‏ . 
أدخل الاستعلام التالی ثم اضغط 5ع : 


select orderid,employee1d,customerid,orderdate,shipcountry 
from orders 

where employeeid = 5 and shipcountry 1n (Brazıl', 'France') 
order by shipcountry asc,orderdate asc 
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ليظهر لك الناتج كالتالي: 


File Edit View Query Project Tools Window Community Help 


dJ New Query | ll | Ê b ë | ê ê HF Êê Û ê ê F 
a3 î | HNDOT NET 2010\PROGRE - | ؟‎ Execute y mM 1g | 2 | ^ | F7 a FF | ا‎ 
| Object Explorer + I X% || / WHITEROSEH:\...\... - SQLQuery3.sq (Summary | ۰ + × | 
Connect 7 ا‎ E | select orderid, employeeid, customerid, orderdate, shipcountrYy آح‎ 
| from orders a 


= l0 WHITEROSE (SQL Server 9.0,1399 - WhiteRose 
El A Uatabases 
Hl LA System Databases 
a Ld Database Snapshots 
E3 ۲ AdwentureWorks 
E3 ۲ CAMDATABASENSQLSERVERNCSE_DEPT. =| 
a lJ fikyDe | 
E3 ۲ HA DOT NET 2010\ PROGRAMMING Ml) | 
HA CA Security | 
EH LA Server Objects 
FH A Replication 
EH LA Management 
E LJ Notification Seryices | 
E SQL Server Agent (Agent XPs disabled] ا‎ "| 


where employeeld = 5 and slHhipcountryY in ('"'Brcazil'", 'France' | 
order by shipcountry asc,orderdate asc 


E] Results 3 Messages 
10372 QUEEN 1996-12-04 00:00:00.0 Brazil 
RICAR 1997-08-28 00:00:00.0 Brazil 
FAMIA 1997-08-29 00:00:00.0 Brazil 
RICAR 1998-01-26 00:00:00.0 Brazil 
HAAR 1998-03-03 DO:00:00. OD Brazil 
VINET 1996-07-04 00:00:00.0 France 
BLONP 199E-US-D4 OO:MO:DO. MO France 
LAMA 1996-1 1-20 OO:DO:OO.OMO France 
BONAP 1997-11-05 DO0:00:00.0OD France 
SPECD 1998-04-22 OO:OO:DO.OMO France 
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کیف حدث هذا 
انظر إلى كل جملة منفصلة.فمثلا الجملة ٤٣1‏ $۴1 تخصص الأعمدة المُستخدمة 
select order1id,employee1d,customer1d,orderdate,shipcountry‏ 
واما الجملة ۴۸0١۷‏ فيعنى بها الجدول الذي سنقوم بعمل الإجراءات عليه 
from orders‏ 
وأما الشرط المتمثل فى الجملة ۴ WHR‏ فهو مايحتاج لقليل من التفكير حتى تصل للإجراء المنشود: 
رقم الموظف 1Dءعرہام‏ ع۴ یساوی °٥‏ 
ShipCountry ®‏ لابد آن تكوj France gÎ Brazi]‏ 
where employeeid = 5 and shipcountry 1n (Brazil, France’)‏ 
لاحظ وجود الرابط المنطقي ۸×5 وهو مايعني أنه لابد من تحقيق الشرطين معا. 
أما الشرط 8۷ 0۸5٤۸‏ فهو المسئول عن ترتيب الناتج من الصفوف وهو كما فى مثالنا سيتم ترتيبه أولاً على جهة الشحن 
ShipCountry‏ م عıJ‏ تlرıخ‏ اÛغطذٹڊ OrderDate‏ 
order by shipcountry asc,orderdate asc‏ 


SELECT INTO إستخدام الجمذ‎ 

تستخدم هذه الجملة لإنشاء جدول جديد يحتوي أو لا يحتوي كم الناتج العائد من جملة 918٣۲‏ فى تنسخ ال reں|Siruc‏ 
الخاص بالجدول وبياناته إلي جدول آخر ممخصص بعد الجملة N۲0].باختصار‏ تعمل على أخذ نسخة احتياطية من ى جدول 
BackUp‏ . 
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إذا تم تضمين العلامة (#) طووط إلى اسم الجدول » فهذا يعنى إنشاء جدول مؤقت فى قاعدة البيانات صعاءر؟ (طا۵مصع)) بغخض 
النظر عن أى قاعدة تعمل عليها الآن . ماذا لو لم ندرجها ؟! ...سيتم انشاء جدول مماثل ولكن فى قاعدة البيانات التى تعمل 
عليها ولیست „.tempdb‏ 

الأعمدة مثل احتواء القيمة 11ں وكذلك وءمر) ه)ول ومع ذلك فإنه لايتم نسخ أي constraints‏ أو مفهرسات وع×عل م1 ولا حتی 
.{(TIggErS‏ 


لتجريب ذلك اتبع الأتي:- 
افتح نافدة استعلام جديدة وتذدکر اناك تستخدم قاعدة البيانات North Wı1nd‏ افخل الإستعلام التالئ تم اضغط F5‏ ° 
select order1d,employee1d,customer1d,orderdate,shipcountry‏ 
into #myorder‏ 
from orders‏ 


لترى كما فى الشكل التالي: 
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E Horthraind a FF Emecute F ي‎ 0 el E BEA) — 2 2 2 
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aE Hêê 3 
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8 lJ Adventure caks 
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لشرح ماحدث ٠:‏ 

قمنا باستخداء الجملة S15٣١‏ وذلم لتعيين قائمة الأعمدة المراد وضعها فى الجدول الجديد » ثم تعيين اسم للجدول الجديد 
ووضعه فى |— INTO #myorder ةذمجلئlب t{empdbh‏ ڌم أتبعناها باسم الجدول الأصلي 6 fr٥۳٣‏ › وحتی لو کنا نعمل علی 
قاعدة البيانات مس طم تذكر ماقلناه بأن الجدول المسبوق ب (#) يتم تخزينه فى قاعدة البيانات الموقتة طلم دص] » وهذه 
الخدارل دق نرد فى اعد انات امرف مادمت لار ال فاه ف الا ر سخرد (غاقك اھا جت ے وار فت بعمل 
حفظ فانه سیتم حذفها تلقائيا من القاعدة الم ع). 

بمجرد انشاءك لهذا الجدول أصبح بالامكان استخدامه كأي جدول معتاد دون أى مشاكل » تنبه أيضاً أن هذه الجداول المؤقتة 
تحذف بمجرد غلقك ل SS MS۴‏ وذلك لأن قاعدة البيانات المؤقتة يُعاد بناؤْها فى كل مرة يتم فتح وغلق SM8۴؟S.‏ 

کے ری آين تقبع هذه الجداول انظر إلي الشكل التالي: 
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ولكي ترى إمكانية اجراء استعلامات عليها كما هو المعتاد مع الجداول الأخرى انظر الى الشكل التالي: 


Fle Edi ew Quomy Debug Toe Window Community Help 
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Table Structure wil SELECT IN T0 pادختl‎ 


فى بعض الأحيان نحتاج إلى جدول ما ولكن بدون المحتوي الخاص به › كان نحتاج أسماء الأعمدة وصفاتها أو كأننا نريد 
تفريغ الجدول من بياناته » ولعمل ذلك فلابد من إدارج شرط لايرجع بالقيمة مںع] .وبعدها فانت حر فى ادراج البيانات التى 
تریدها. 
لعمل ذلك » ادخل الاستعلام التالي فى نافذة استعلام جديدة على قاعد البيانات :North wind‏ 
select order1d,employee1d,customer1d,orderdate,shipcountry‏ 
into #myemptyorder‏ 


from orders 
where 0=1 


لتشاهد كما بالشكل التالي : 


2 طت لسا 7 | ا زا | جعت سب ب 
2 
Olbject Esplerer > 3 ¥ Sql Qoerytsgl - HOSSAM-PCT JI" | SQL Query sql - HOSSAM-PCu. J)" |‏ 
Ele EET, ERPISTESLA, CUSEORETIA, order dartE, ANIPEOUATEEY‏ که E3‏ 
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8 lJ medel 
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mH J Tables 
E Tienoorany Tables 
A O dibe Hrmmemptyordtı 
E J dba # my ordêr 
E r 
ك‎ dy Ty 
E Gg Frogremuma bility 
8 Cj Serige Broke 1 
E I Storegê 1 
8 Î Secu . 
j AdveniureNorks I0 rewfla] aEfaevad) 
E lj Mortman di 
9 J SEU; 
E CG Serger Obperts 
8 Ca Fegiication 
E Lj Managemen 


1 + | Î Query executed successfully FOSSA I= FASQLENPRESS BO SFA) | hosa Pî 


هل لاحظت الشرط الغريیب 0=1 eإعطw‏ ؟! 

إنه شرط لن يتحقق وهو ما ذكرناه (بإمكانك تخصيص أى شرط لن يتحقق كما تشاء) وبهذه الطريقة فإن م۲ںاںہاء اطم يتم 
نسخها فى قاعدة البيانات المؤقتة الم _م) ولكى ترى الجدول الناتج اذهب كما فى الصورة › ثم قف على المجلد Temporary‏ 
Tables‏ ڌم اضغط على الزر طیه؟ه] فى الأعلى أو بالزر الأيمن واختر طیع۲؟ه] . 


وكما سترى فإن الجدول يحوى الهيكل فقط دون بيانات وللتأكد من ذلك فقط قم بعمل جملة 5۴1/8٣۲‏ على الجدول لترى كما 
بالشكل أسماء الأعمدة وفقط من دون أيه بيانات ٠‏ 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


ا 
i) New Query | Bı | BÈ | Ë lH 3ã‏ 
Hf | Norihraind | f tate F n ¥ FAIT SY IOEOIS= 2FENL‏ 
bjet Erplarêr e HH SM eeryd sql - HOSSAM-FPOLNF | SQL Rouen sgl HOSSAM-PE N |‏ 
Connect | 47 2 4 select * FAM Fuyemptyorder‏ 


3 lj HSSAM-POSQLERFPEESS (SQL Sener 90D = ho 
J] Daiklebaleêî 
2 3 Stem Databases 
E LÎ naet 
E lj model 
A lJ mE 
1 LJ tEmpdb 
A O Tabi 
1 J TêmpêraFy Tablêê 
A O dbo fmyempîtyorder 
1 Û dî êr ardii 
A Og ieee 
1 J momma 
A a Programmability 
2 Û HERE Biqiker 3 mM 
A A Sage 
a E ity 
E lj îdwentureiiiorks 
از‎ Hertim 
E KG secur, 
8 Ci Serie Qbjects 
Ei L_] Fêplıêšlıörî 
8 ü Management 


TI] Reits Ty Messages 


٣ 1 ۴ Û Query executed successfully. FHOSSAM-POA SQ LEXNPRESS O SPA] | hossam-Piihossam (F4 


إدخJi‏ ilئبlنlٽ Inserting Data‏ 
إن من أهم الإجراءات التى تتم على البيانات هى عملية إدخال البيانات إلى الجداول» ونقوم بهذا باستخدام الجملة N5۴17‏ . إن 
هذه الجملة غاية فى البساطة عن أى جملة أخرى › ذلك لعدم فاعلية استخدام ية عبارات شرطية مJû WHERE - ORDER‏ 
BY‏ » وتتكون جملة ]NS٤R1‏ من الآتي: 

INSERT INTO <table> 


(<column1>, <column2>, ..., <columnN>) 
VALUES (<valuel>, <value2>, ..., <valueN>) 


ولتفعيل هذه الجملة نضعها فى المثال التالي » وهو إضافة صف جديد الى الجدول عم ماط؟ فى قاعدة انبيlانlت Northwind‏ . 
لننظر إلى الجدول أولاء افتح 85۷5۴ تم تصفح التسلسل الشجري على الیسار إلى ان تصل الى قاعدة البیانات ×٥٤! wd‏ تم 
اضغط العلامة (+) حتی تصل الى الجدول ءإمممط؟ ثم اضغط كلك یمین ثم اختر فتح الجدول 1طا1 ١ء‏ م0 کما تری فی 
الشكل فإن الجدول لايحوى سوى ثلاثة صفوف : 


Er at C\SQLEXPRESS (SQL Server 9.0.5000 = | TT Results ES | 
1 ست تتت ب#بو اداو لے‎ | 

E Û System Databases ات ب‎ Lonmpenyhlame hane 
mH lÎ master 1 |1| Spendy Epes 0 59831 
7 | ا‎ 2 rated PFackaga (SU) S-318 
@ |j mdb ډ ك‎ Federal Shipping (0G) S9931 
Ê lJ tempdb 

I lJ AdventureWorks 

2 lJ Northwind 
E Û Database Diagrams 
E GEE 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


والآن نأتى لإدراج صف جديد بالجملة ٤إمیءہ!‏ 
افتح نافذة استعلام جديدة ثم أدخل الإستعلام التالي واضغط ۴5: 
insert Into shippers ( companyname, phone )‏ 
values (EgyptNetwork', '+0220801756')‏ 


لتری النتيجة كما فى الشكل الى 


FilE Edît êw ery  Deêébuğg Ta Mindêw Lammy Hap 
O EET ET 


HY  Rorthraand = | F Eueeuie F ا‎ lT | BOI EEE 
betî Bıplofer + Hl SL Query T1sql - HOSSAM- PCL." 
Cennet” YF? 47 ق‎ insert into ahippezr3 compan yrame, phones 
| E [ğ HOSSAM-PCNSQLEXPRESS [SQL Server 9.0.5000 - » | ا و‎ 
j Uatabaiêê 
DO Stem Catebares 
4 J Tl 
TH lj medel 
j msdb 
| êi 
A LJ Hvar ior 
J PA girtir 
H KG Database Diagrams 
1 Tables 
E Û têm Tablêî 
A Û dbierategoiez 
8 Û dbo agtornert usborrwe herro 
FE ÛÎ dba. urtomagrDermogra phic 
E Î dbo:Custormers 
E Û dbaEmplayêkî 
1 Aba Em py êêl romî ۴ 
5 O dbo Order Details 1 
E O jbo ûrderE ودج و‎ 
E Lal doo Products li ramin] aÃËactedî 
E ll dba.Rêgion 
A J dba Ship pas 
"A Û dba. Supper 
8 O jbo. Terr grit 
Eg ime 
A Lû 3monymnê 
TH LL] Prêağfarmma balty 
A CI Service Biol 
A CA Forage 
ا‎ + | Query executed successfully | HOSSAM-PENSGQLEXPRESS 0 3P4) | hossam-PCNhessarr 


وتظهر رسالة كما بأسفل تخبرك row (s) affected)‏ 1( . 

لشرح ذلك » لربما تساءلت اولاً لماذا أدخلنا قيمتين بدلا من ثلاث (هذا اذا كنت قوي الملاحظة © )؟ 

والجواب هو أن القيمة التى لم ندخلها هنا هى 12إءمماط؟ وهى بمثابة ران)ممل] للعمود وتم تخصیص نو عھا لتولد تلقائيا دون 
تدخل من المستخدم حیٹ ڌم SQL Server‏ بهذه الوظيفة نيابة عنك » لذا فإننا فقط سنقوم بادخال قيمتيj‏ ھم (Companyname‏ 
مصەطم, ) وذلك حتى لايحدث مشاكل غير متوقعة لم نترك الاختيار لإم۷إء؟S 8Q1‏ وقمنا بتعينهما فى الاجراء ثم قمنا بتعيين 
القيم المخصصة لهما بالترتيب ('0220801756+' .values (EgyptNetw01K',‏ 

هناك بعض القيود على الجملة ]NS ٥67‏ فمثلا عندما نريد ادخال قيمة على جدول ٿانوي لجدول أساسي foreign key table‏ 
وهذا الجدو ل الأساسي لیس فيه Related Parent Record‏ فحتما سيظهر أخطاء وذلك لأنه لابد من وجود هذه القيمة فى الجدول 
الأساسي أولاًء على سبيل المثال الجدول Shoppers‏ سنعتبر ہ ع[طھ) .۲ للجدول Orders‏ الذي یحو ی عمود ۳٣.)‏ یسمی 
Ship Via‏ والذی بدوره يقوم بعنونة العمود ShipperID‏ فى الجدول Shippers‏ (فقط عد القراءة لتستو عب © ( فلن تستطيع اذا 
أن تدخل قيمة إلى الجدول وم لإ0 قبل ان تدخلها فى الجدول وإممماطS؟.‏ 


نعود إلى مثالنا » للتأكد من أنه تمت اضافة القيمة السابقة للجدول ءبديهي أن تقوم بعمل استعلام على الجدول لنرى القيمة ولا 


أرى أفضل من الاستعلام * 9818٣١‏ للجدول كما بالتالي: 
select * from Shippers‏ 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


ليظهر عندك النتيجة كما بالشكل التالي : 


File Edî View Query Debug Tock Window CGommuniy Help 
Û New Quey | Û | Bı | 2ã  ã | Ê 


2  Northkeîind =F Execuie F ا ي‎ i E | EB HEI = 2 ع چ‎ k8 2 
Libşercî Esplorer e HJ O uery sgl « HOSSAM- FO 
konne” | ¥? 7 2 SEleEETE °“ from Shippers 


LO HSA R-PLNSLERPRESS SL SERE YO SN = = 
3 تةخاقا قا‎ 
O Shem Databaiat 
A lj fmastêr 
A lj madzl 
2 اقش إا‎ 
2 اققا إا‎ 
J Adventure cake 
J NHertirmnd 
2 LÛ Uatabağê hağfafîê 
I 1T ablê 
E Ld sêm Tabla 
A O dbêrCateg arê 
HI Û dbea.fustamerfustamerlema FF | 4 1 
E Û dbê Customer Deriographiês I] Feu HH ۳ 
E Î dê Custom : 


A I dbaÊmplay 
a EREY Spay qê 3) II 


` Urked Packages 503) 555-3199 
Federal Shipping OS] SIT 
Eggi Helale ۹Z ABOUT TSE 


I Û dbaêrmployeêT emitotiês 
E Û dêr ûrdêr Detail 
Î Abê îrdêrê 
E Û dba Produ 
_ dba. Region 
A Û dbeShippers 
E Û Abe Su pple: 
Ej ll Abê. Têr ûrrêî 
A LJ Yiêwê 


ج 
= الع a‏ = 


mm a ت طط‎ 


r 


A LÛ Synonyms 

aA û Pragqramrmability 
E] [Û] *ERE#E Brolcer 

1 LG Forage 


r‏ ت 
I aru rrThyr‏ 


4 . mr ۴ i Query esecuted succesfully. HOSSAM- PO SQLEXPRESS B0 SFA] | Bessam-FCihas 


قيمة أه » فكلا العمودين السابقين من النوع Character data type‏ »فلو کان أحدهما مں النوع Integer‏ مثلا فلن يقبل القيمة 
اص د ا 


تحديث llڊبlنlٽ Updating Data‏ 
ماذا عن تحديثك لبيانات تم ادخالها بالفعل ؟ هذا هو ما سنقوم به باستخدام الجملة 05۸1٤‏ .عندما نستخدم هذه الجملة لابد 
من توخى الحذر مع جملة الشرط W1۸۴‏ وإلا فإن التحديث سيكون لجميع الصفوف فى الجدول. 
للتعرف على هذه الجملة إليك قاعدة كتابتها ٠‏ 
UPDATE <table>‏ 


SET <column1> = <valuel>, <column2> = <value2>, ..., <columnN> = <valueN> 
WHERE <predicate> 


کمتال عملي» لنفترض ان الشركة EgyptNetwork‏ قررت تغییر اسمها إلى EgyptSoftware‏ مثلاءلکي نجری هذا التغيير فى 
قاعدة البيانات ينبغى تحديد اى من الصفوف سيتم اجراء التعديل عليه»و لأنه يُحتمل وجود أكثر من شركة فى قاعدة البيانات بهذا 
اللإسم لهذا سيكون ال رم ليس اسم الشركة ولكن سنستخدم 4مم مذط؟ كمفتاح للتعديل على الصف. 


مثال لتحديث بيانات صف فى الجدول: 
افتح نافذة استعلام جديدة › وتأكد أناك علي قاعدة البيانات 4مس ط٤إه×‏ ثم ادخل الاستعلام التالئ: 
Update shippers‏ 
Set companyname='EgyptSoftware’‏ 
Where shipperid=4‏ 


C# 2010 and MSSQL Serve 2008 برمجة قواعد البيانات باستخدام‎ 


حسام كمال محمد 


وتلاحظ بعد ضغطك ۳5 ظهور النتيجة (dإء٤ء٠a۴۴‏ (5) ٥#‏ 1) ولرؤية اثر التحديث كل ماعليك هو ان تفتح التسلسل 
الشجر ي لقاعدة البيانات على اليسار من rعorاExp Object‏ وتفتح الجدوJ shippers‏ بالضغط كلك یمین وتختlر Open Table‏ 
أتشاهد كما بالشكل ٠.‏ 


Fhoirie 
EN EEE" El 
(503) 555-3159 
{S03} SS51 
HUTA 17S 
FEE 


Table - dbo.Shippers 
Shipper ID Compamy Flame: 
۳ ' Speedy Empress 
Lirêbedl Package 

Federal Shipping 
EğyptSo Ptetareê 


Help 


tL ormirm rity 


WT rr gra? 
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لس E‏ لكا : 

| Object Etplarer 
Connect” WI E 
a lB WHITEROSE (SQL Server 3O13 - WhiteRose Hossam] 

E LM COatabases 
a OO System Databases 

a3 La Database Snapshots 

J| Ader tureWorks 

lL CADA TABASEN SQL SERMERMCSE DEPT.RADF 

1 

BH 


اک 3 | =6 | ج ؟ 


أ 


ا ا ل 


La Ûatabaze Ûregrarns 

la Tables 

a= CO Syîem Tables 

1 Abo. Categories 

Hho Cu storrverCustomerDerro 
Aba. ust ore Liem o qira phics 


# 


dbo. Curt orTruers 

Aba. Employees 

dbo. Employee Territories 
dbo. Order Details 

dbo. Orders 

dbo. Products 

dbo. Heg on 


ع ل ج 


ا ا ا 


dbo. Shippers 
dbo. Suppliers 
dba; Territories 
E 


|2 
ا 
ا 


ا ا ا ا ا ا ا ا ا ا ۰ 


= 
تچ 


بلا شك الأمر بسيط سنستخدم الكلمة $81 مرة واحدة ثم سنستخدم الفاصلة لتحديد أى من الأعمدة نرید تغيير ها فى اى صف› 


كمثال على ذلك لنفترض تغيير اسم الشركة بجانب هاتف الشركة: 


لتشاهد التحديث على العمودين كما بالشكل : 


FFE 

523] S55-431 
{SOI} SSS-3193 
{SOT} SS31 
13350 

EE 


Campa yam 
بوانت‎ Express 
Linited Fackage 
Fetieral Shippirrg 
EgypiSaf beware 
TEL 


Update shippers 

Set copmanyname = 'EgyptSoftware’, 
Phone='19350' 

Where shipperid = 4 


Filê Etirk Ea Pra jêtet Iiery Desi gq rrr lols WI FE ga e TTT TUL FY Help 
: I. New Query | Bî | tb Ê ® E AF I GA EB BF, 
A EH & -- | ؟‎ RIE | 2 ك‎ 
| Object Explorer - 3 ¥#%| Table - dbo Shippers 
| Connect | 43 E | ShipperID 
ا‎ 3 li WHITEROSE (SQL Server 3.01399 - WhiteRose. Hossam] سے‎ Fk 1 
E Ca Ûalabases ا‎ 
Bi CO Sytem Databases 3 
IB LK Ûatabase Snapshots 4 
E lJ Advenburetilorks د‎ EE 
a ll CAPATABASENLSQLSERVERNCSE_DEPT.MMADIF چا‎ 
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= lJ CWEBAP PST ORESSTAPP DATA HORTHIMND.MC 
EH CKO Ûatabase Olagrarms 
A lL Tables 

System Tables 

dbo. lCabeg ories 

dbo kustomertustomerDermo 

dl ko. usto merlhermographics 

î bke Custom êrs 

dba Errpleyrees 

deo. ErruployeeTerritories 

î ba. Order Details 

dea rders 

d Bo. Products 

3 bke Region 

dbo. Shippers 

dl ko. Suppliers 


| E H El E E El E E El E El E 


C# 2010 and MSSQL Servef 2008 برمجة قواعد البيانات باستخدام‎ 


حسام كمال محمد 


حذف llڊيlنlٽ Deleting Data‏ 
من الأمور الهامة التى يجب أن تعرفها فى التعامل مع البيانات هى حذف البيانات.ونقوم بهذا الأمر باستخدام الجملة ٤1٤۲۴‏ 5. 
وكما نوهنا فى الجملة 0۸1۴ا من توخى الحذر مع جملة الشرط ۴غ1 فينبغي أيضا توخي الحذر مع الجملة 

E1٤‏ » فمن السهل حذف كل الصفوف اذا لم نحسن التعامل مع جملة الشرط. 

تقوم جملة 5٤1 E1۴٤‏ بحذف الصف بكامله بغض النظر عن تحديد اى قيم فيه» وتتكون جملة الحذف من التالي: 


DELETE FROM <table> 
WHERE <predicate> 


جملة where‏ اختيارية ولكن نكرر التحذير أنك دونها ستحذف کل شی. 
ادا اردت ان تحذدف يعص 1 لسجلات من الجدول shippers‏ : فعايك لخذدد المفتاح الرئيسي او لا لکل صف رفك حدذفه» ومثال اين 
ذلك قم بكتابة هذا الاستعلام واضغط f5‏ : 


Delete from shippers 
Where shipperid = 4 


من المؤكد انه سيظهر لك هذه الرسالة (d١ء٤ء٥aFF‏ (s)#w٥ع ٠)1‏ قم كما فى السابق بتصفح الجدول ءإمممنطء لترى 


انت : د کما بال ك : 


File Edît Vie Propecl Query Desigmer Tools Winda Lormrnunity Help 
ا ع | وا | عت سھل .ای‎ O چ | فا‎ AI A BE lê FO _ 
اک و | ک5 | چ ۴|" ق ك‎ 
Dibjzset Ecplorer - 3 چ2‎ Table - dbo Shippers > «x 
Lonnect 7 E Shipper ID Lompan rame Parê I 
۳ ۳ WWHITERLFYSE (SL Serwer SO.1 390 - WhiteRose Hossam] ۴آ‎ 1 Speedy Express SOS) SSS-S31 
21 KO ÛOatabases ا‎ LIrnited Fackage (SITY SSS-T IIS E 
3 Lm Spstem Uetabases Federal Shipping S03) 555-SA31 
E li ÛUatabase Snapshots د‎ FF ARE 
I LJ Advenburetiorks 
2 LJ CADATABASELSULSERVERNCSE_DEPT. MDF 
3 lJ BAWEBEAPPSLORESTAPP_ DAT ANOR THUVIRMD MIC E 


تم حذف الصف الأخير الذي يحوى اسم الشركة وهاتفها كما ترى. 


H3 Ka Ûatabase ÛDilagramıs 

1 LO Tables 

N Sestem Tables 

dl bea ateg aries 

dbo Customer ustomerDermo 
dl eo uusto mer lero gra phacs 
dj ke uso mers 
dbo-Erruploygees 

deo. ErmuplogyeeT errmitories 

dka. Order Details 

dbo Orders 

dkeao-FProduacts 

î bo. Regıan 
dkea. Shippers 


ا ا غ ا ا ا ا ا ا ا ا 


لا تحاول حذف اى من العناصر الثلاثة فى الجدول (لأن هذه العناصر مرتبطة كمفتاح ثانوي ۴.۸ مع الجدول وإملإ0) وسينتج 
database error‏ لآأن SS۴‏ يمنع حذف العناصر فى جدول مرتبطة بجدول اأخر(يمكنك الاستزادة بالرجوع مرة اخري لفهم 


المفاتيح فى الفصل الأول). 


ماذا عن حذف كافة البيانات دفعة واحدة بدلا من مجموعة سجلات ؟ » سنستخدم الجملة PRU N٣۸ 1۴٤ 1۸81٤‏ فقط تعطها 
اسم الجدول وهى ستتولى المهمة ›» وهی أفضل من جملة 5٤1٤1۴‏ لأنها لاتقوم بعمل ع 1ععه] وتعني حفظ كل صف من 


الجدول فی ]1ا ه1 قبل حذفه فى حين أن الجملة 5٤1٤1۴‏ تقوم بذلك. 
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خاتمة الفصل 
فى هذا الفصل تعلمنا كيفية التعامل مع البيانات وكيفية اضافة وحذف وتحديث هذه البيانات وكيفية 
المقارنة بين البيانات واستخدام المعاملات كاهأج٬ممO‏ . 


C# 2010 and MSSQL Servef 2008 برمجة قواعد البيانات باستخدام‎ 


الفصل الرابع 


استخدام الإجرا ءات المخزنه Using Stored Procedures‏ 


حسام كمال محمد 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Serve‏ حسام کمال محمد 


Stored Procedures مئاهي‎ 


تعتبر الإجراءات lالkخijة Stored Procedures‏ والتي سنشیر لها فى الكتاب ب (8۲) جمل ا8 تمكنك من عمل اجراءاتك على 
قاعدة البيانات بصورة متكررة. 

بامكانك انشاء procedure‏ مر ة ة وأحدة تم تعبد استخدامه أكثر من مرة کی فى البرنامج الذي تعمل عليه. 

لماذا کل هذا ؟ .. هذه الطريقة ستريحك كثيراً حال وجود اخطاء فى الكود المكتوب وعمل اصلاح لهذا الخطأ » كما أنها تمكن 
تطبيقاتك من الولوج الى قاعدة بياناتك بطريقة سلسة ويكفاءة. 

في هذا الفصل ٠‏ سيّْصبح عندك المام جيد بال 8 وكذا كيفية استخدامه داخل أكواد برامجك بال ٥#‏ 


في هذا الفصل سنتعلم : 
کیفیۂ انشاء ۲؟§ 
ه كيفية التعديل على ۲؟ 
SP definitions ضا|رعeتwl e‏ 
م اعادة تسمية SP‏ 
ه كيفية استعمال 8۲ داخل أكواد C#‏ 
حذف °۲؟ 


Stored Procedures sli في‎ 

یُمکن لل ۲ی أن تحوي المعاملات ۶۸٣»‏ والتي تعني أننا يمكن ان نعيد قيم مدخلات ومخرجات › حتي القيمة الافتراضية 
صفر ٠‏ ويمكن ان تعيد هذه المعاملات اكثر من قيمة او لاشى. (فكرة المعاملات مشتهرة فى عالم البرمجيات وهي تعتبر متغيرات لكن لإرجاع 
قي م للدوال) [ 

یُمکن استدعاء $۲ من داخل کو اد برمجية كال C#‏ مذلا وأيضا يُمكن استدعاؤ ھا من داخل $۲ آخر. بسبب قوة وسلاسة ۶۲؟ 
أصبحت هي الصيغة الأكثر انتشاراً في عالم برمجة > قواعد البيانات» خاصة فی البرمجيات المتقدمة الى تستخدم الطبقات 
المتعددة وم 0ن†icaاApp Mul] titier‏ وكذلك في ال ععزرإم؟S‏ ا۷6 ما فيه من تداخل بين قطاعات متعددة من البنية التحتية 
كالشبكات والأجهزة الخادمة وإمرإمS‏ » لأن لها القدرة على التخفيف من حدة ضغط الطلبات sاوعuوه ۸R‏ على هذه الخوادم 
وعلى ال لشبكة. 


كيفي SQL Server ga Stored Procedure JذİE Janell‏ 
سنقوم الآن بإنشاء أول م8 لنا والذي يقوم بسرد أسماء العاملين فى قاعدة البيانات التي نعمل عليها 4مس ط)اهN‏ » وبالتالي لن 
نحتاج الي عمليه ادخال في ۲؟. 


1 افتح SSMS‏ تم قم بالاتصال بقاعدة البيانات (لاحظ هنا اننا نستخدم SERVER Management Studio‏ ا91 النسخة الكاملة 
وليس ووء٣م»5)‏ وف ي كلتا الحالتين فان الاجراء سينجح كما ذكرنا ف يأول الكتاب فى التبديل بين النسختين لن تجد أي فارق. 
۳ قم بتو سعة شجرة قواعد البيانات من اليسار تم اختر قأعدة البيانات Northw1nd‏ تم کلک یمین واختر New‏ 


C# 2010 and MSSQL Serve 2008 برمجة قواعد البيانات باستخدام‎ 


حسام كمال محمد 


create procedure sp_Select_All_ Employees 


لترى النتيجة كما بالشكل التالي: 


as 
select 
employee1d, 
firstname, 
lastname 
from 
employees 


Fil Ed Yim query Project Debug Tools Window  Lommunity Help 


E E EE EEE EET 


1 BÎ | Northwind -| f exete * E < Hel A BEDI SEE 


SQLQuery1.sql ...1hossam {53} چ‎ 
create procedure 3p Relect All Employees 
a3 


2E lEZE 


EEE 


Emp loyeeid, 
FiF2LCnHAME , 
lastname 
Ero 

Emp lOyEEaza 


4 ej | 


1 
3ا‎ Messages | 
Loumuandls=) couplsted successfully. [ 


۳. واتنفید هذا الإجراء ¢ أدخل الاستعلام الال ¢ تم اضخط F5‏ ° 


لترى النتيجة كما بالشكل: 


7ھ | ع چ | 


ıi 


3 FAA Ba AEA: 


SQLQuery1.sql ..1hossam (53J 
ExECUtE 3p _ PBelect A11 Employees 


4 


E Results Ea MMES=aQES 


Hrstname | lastname 


1 |1 بصة أ‎ Da¥olin 


OO 


2 | 2 باع‎ Fuller 


| 3 Janet Leverling 

a 4 Margarel Peacock 

E 5 Steven Buchanan 
E | : Michael ENI 

i: E Robert King 

E | 3 Laura Lallahan 

3 3 AE Dodsworth 


ject Explarer 


dnnert > YH ۲ 7 

1 ۳ , SQL Server 10,50,1617 - eaglefhossarn) 
E1 ÛJ Databases 

I 35Ystem Databases 

I Database Snapshots 

Lamb‏ ا 

lJ Military 

lJ Milikary_5ystem_3 

u mojoportal 

lJ Morthnind 

lJ Reportserver 

| J| ReportseryerTempDE 

J Security 

KO Server Objects 

O Feplication 

CO Management 

1 SL Server Agent 


HEHE EEE E E & 


execute sp_Select_All Employees 


PL EE EET 
: ب‎ 1 Moarthwird + | fF Execute FF WM qy 
Object Explotêr 
connect > A1 BT a T 7 
E ا‎ , (OL Server 10,50,1617 - eagle thossarn) 
El CI Databases 
l_J sYsktem Databases 
KJ Database Snapshots 
۲ Lamb 
lJ military 
لا‎ Military_Systern_3 
lJ mojoportal 
| Jl Northwind 
lJ Reportserver 
| J RepartseryerTempDE 
LL] Security 
J Server Objects 
KO Replication 
CO Management 
E SL Serwer Agent 
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لتو ضیح مأحدث۰ 
قمنا بانشاء SP‏ عن طریق الجملة Create Procedure‏ < وقمنا بالفصل مابين اسم الاجراء والمعاملات (والتي لم نستخدمها کے 
مثالنا) بالكلمة المحفوظة ۸5 والتي تسمى مإںاهمع:S‏ وما بين الإجراء الفعلي (جمل اQ؟).‏ 
Select‏ 
employee1d,‏ 
firstname,‏ 
lastname‏ 
from‏ 
employees‏ 
بعد أن قام S58‏ بانشاء الإجراء أنا » قمنا بعمل تنفيذ لهذا الاجراء عن طریق الأمر: 


execute sp_Select_All Employees 
على تعقيدات جمل 51 التي يتضمنها برنامجك › وبالتالي 5۲ لا يعد صعبا في حد ذاته.‎ S۲ هذا كل شئ » يتوقف صعوبة ال‎ 
تنوبه:‎ 
‘$ الاجراء قد بدا بالحرفين _ مء » وجرت العادة على تسمية الاجراءات المنشئة بواسطة 1 1-5 مبتدأة ب‎ ١ أعلك لاحظت‎ 
ب م× وتعنى ءإuاdءمعoإم dمdلxtenء » وليست هذه قاعدة » فقد نجد مئات من‎ 1-S0[ وتسمية الإجراءات المنشئة خار جح‎ 
.1-؟S0ا[ الاجراءات مبتدأة ڊ ۽ لكنها فى الحفيفة ليست مكتو بة ب‎ 


لماذا التنوبة؟ 
في الحقيقة لاينصح باستعمال _مء في مقدمة اسم الإجراء المزمع انشاؤه وذلك حتي تكون عملية البحث عن الاجراء اكثر 
سر عة » لأنني نوهت ان أغلب الاجراءات المكتوبة ل امك -1 تبدً ب مء وبالتالي سيقوم محرك قاعدة البيانات بالمرور على هذه 
الاجراءات واحداً تلو الآخر حتى يصل للاجراء المطلوب » فعند اأبحث عن أي اجراء بحدث هذا السيناريو: 
e‏ يقوم SQL Server‏ بالبحث داخل قاعدة البيانات Master‏ ایتداءاً عںل هذا الإجراء »> ومن من المعروف أنها تحوي مثئات 
الاجراءات مبتدأة ب _مء » فإذا وجد الإجراء المطلوب فإنه سوف يقوم بالمناداه عليه عمزااهء. 
م اذا كان الإإجراء غير موجود في قاعدة البيانات إع)ووصم وهو الغالب » فانه يقوم بالبحث عن هذا الاأجراء داخل قاأعدة 
البيانات الحالية (database_name.stored_procedure_name)‏ . 
يعني فى النهاية سيمر على قاعدة بيانات غير معنية بالبحث حتى ولو قمت بتوفير اسم قاعدة البيانات الحاوية للاجراء! 
كما ينبغي التنوية بعدم استخدام اسم اجراء موجود في قاعدة البيانات الرئيسية إم)ووم » صدقني حتى ولو وفرت اسم قاعدة 
البيانات الف انشأتها بنفس اسم الاجراء سينادي الاجراء الرئيسي و الفا عدة mas‏ 


إنشاء Stored Procedure‏ يحوي معاملات 


سنقوم بإنشاء 8۲ يقوم بعرض عدة طلبيات لموظف ماء سنقوم بتمرير مُعرف الموظف 5 الى $۲۶ ليتم استخدامه في الاستعلام. 
١‏ قم بادخال الاستعلام التالي › واضغط ۴5 ٠‏ لترى رسالة "' yااںfووعsucc mand)s( completed‏ ص0" في نافذة النتائج. 
create procedure sp_Orders_By_Employeeld‏ 
@employee1d ınt‏ 
as‏ 
select order1d, customerıd‏ 
from orders‏ 
where employee1ld = @employee1ld;‏ 


ت ولتقوم بتنفيدذ الاجراء السابق › قم بادخال الأمر التالي > مع قيمة المعامل" ۲ " لترى نتيجة كما بالشكل : 
execute sp_Orders_By_Employeeld 2‏ 
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Debug Tools Window Community Help 
3 8 8ة‎ 
+ ¥ Execute pÞ FM 2 اچ‎ 1 
| _SQLQuery1.sql ...\hossam (53) SS. 
cEeate procedure s3p_ Orders _ By _ Employeeld 
BHermployeeid int 
aS 
së let 6FdeEFilid, CGuUusSTtOoOmEeEF iA 
TFFOmM OFderFs 
whëerê emp loyeeid = demployeeid: 


م سے س ر ص 
EF | 2b =‏ س سڪ 


leihossam) 


execute sp _ Orders By Employeeld 4 
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لعلك لاحظت أننا قمنا بعمل تنفيذ أكثر من استعلام في نفس النافذة › وهما تعليمتي الانشاء والاستدعاء للاأجراء السابق › وهذا 
ما يتميز به م ۷إم؟ 8Q1‏ عن باقي أنظمة ادارة قواعد البيانات » كما ويمكنك أن تظلل استعلاماً ما ليتم تنفيذه بصفة مستقلة. 
ولتوضیح ما حدث » فالأمر كما تعلمت مسبقاً « اذا قمنا بانشاء اجراء مُخزن 8۲ عن ط¦طريa‏ !لمر CREATE PROCEDURE‏ 
ثم نضع اسم المعامل المرغوب كما في مثالنا > ام1 لزءءرمام مء قبل الكلمة المحفوظة ۸١‏ واما الكلمة م فهي نوع المعامل 
data type‏ › تم قمنا بوضع الشرط wee‏ › و الذي فيه نحدد ان یکون اسم العنصر في العمو 3 employeeld‏ مساو للمعامل 
٠ @employeeid‏ 
where‏ 
employeeid = @employee1d;‏ 
هذا كان مثال بإدخال معامل » ماذا عن استخدام معامل في الإخراج ؟ | 
معاملات الاخراج كإعاعصهإة۴ اuم0ut‏ تستخدم في تبادل القيم مابين الاجراءات المُخزنة و8۲ » ولكن أحياناً تستخدم في الأكواد البرمجية 
مثل #© » لذا هذا المثال سيكون في كيفية انشاء معاملات اخراج يتم استخدامها فيما بعد في برامجنا » وسوف نعرف كيف نسترجع قيمة 
بخلاف القيمة '"صفر". 
١‏ ادخل الاستعلام التالي › تم اضغط ۴۳5 للتنفيذ » لترى الرسالة " y[اںfیsعsucc‏ etedاcomp Command)s(‏ " في نافذة النتائج. 


Create procedure sp_Orders_By_Employeeld2 
@employeeid Int, 

@ordercount int = O0 output 

as 

select order1d,customer1d 

from orders 

where employeeld = @employee1d; 

select @ordercount = count(*) 
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from orders 
where employeeld = @employeeid 
return @ordercount 
يُمكنك الان اختبار الإجراء السابق » فقط أدخل الاجراء التالي في نافذة الاستعلامات » لكن تنبه أنك قد قمت بمسح الاستعلام السابق › او‎ -١ 
قم بتظليل الاستعلام التالي » حتى لايفهم نظام قواعد البيانات انك تنشئ اجراء مُخزن مرتين:‎ 
Declare @return_value Int, 
@ordercount 1nt 
Execute @return_value=sp_Orders_By_Employeeld2 
@employeeld=2, 
@ordercount= @ ordercount output 
Select @ordercount as '@ordercount’ 


Select ‘Return value' =@return_value 


TE e a N ك | د د | ك حا | فإ )و‎ 
سس کی‎ 
„7 SQLQuery1.s5ql ...1hossam (53) 
BAordercount int = ÛU Output 
a2 


2ElEZL orFAeEEFiA, Customer if 

From DOEQAEFES 

where employeeid = Hdemployeeid:; 
zElect BHordercount = count l^] 
from OEAErFS 

where eEmployeeid = Bdemployeeid 
FEtuUrFH BHordercount 


DEZlare Hreturn Yalue int, 
BAordercount int 


xECuUtE Hreturn Yalue=szp Orders By Employee Ida 


EZE BMordéercount a3 'BMordercount ' 
I'RHetUrnHn Talue' =AdrFetUEH TaAlUE 


3 MESSaAE5 


custoarmerid 


Return Yale 


query executed successfully, local (10,50 RTM) eagleîhossam 53) Northwind OU:‏ ي 


كما ترى فإن النتيجة المرجوة هي "96". 
ولتوضیح مأحدث › فاننا شف المعامل @ordercount‏ تم قمنا باسناد القيمة "0" له 
Create procedure sp_Orders_By_Employeeld2‏ 
@employee1id Int,‏ 
@ordercount Int = O output‏ 
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as 
select order1id,customer1d 

from orders 

where employeeld = @employee1d; 


واما الكلمة امه فهي من الكلمات المحفوظة والتى توضح أن هذا المعامل لإخراج القيم » لاحظ معي الفاصلة المنقوطة التي أنهينا بها 
الاستعلام أعلى (;) - كما قمنا بإضافة الاستعلام التالي : 
select @ordercount = count(*)‏ 
from orders‏ 
where employeeld = @employeeid‏ 
كما نوهنا على الفاصلة المنقوطة والتي يبرز أهميتها هنا لأنها تفصل مابين الاستعلامين السابقين › واسندنا الدالة (*)٤uهء‏ الى المعامل 
@ordercount‏ تم استرجعا القيمة باستخدام الكلمة المحفوظة ٣إں)ع]‏ 
return @ordercount [‏ 
ومن الملاحظ انه دائما ماتعود الدالة C00 N1‏ برقم صحیح N۲٤6٤‏ »لذا فأنت مسبقاً تعرف أن الدالة ۸٤10 R۸‏ ستعود برقم وهو "96" 
کما فی مثالنا. 
بالقطع هناك طرق عدة لكتابة مثل هذا المثال » لكن هدفنا هو تعليم الطريقة وليس الفكرة › والأهم هو كيفية استخدام هذه الأمثلة مع أكواد €C#‏ »ومع 
هذا ستكمل طريقنا في هذا الفصل بكيفية التعديل وحذف الاجراء المُخزن. 


Stored Procedure ر‎ Jيدعت‎ 
الذي أنشأناه‎ sp_select_All_ employees SP سنتطر ق الان لكيفية اجراء تعديلات على ال‎ 
اتبع الخطوات التالية.‎ 
: F۴5 أدخل الاستعلام الال تم‎ 
Alter procedure sp_Select_All_ Employees 
as 
select employee1d,firstname,lastname 
from employees 
order by lastname,firstname 


لتری کما بالشکل: 


TEE a r 7‏ سے 2 ا 
SQLQuery3.sql - (..OOTI\Hossam (51)J)*|‏ 7 | 
j BG2RIter procedure 3p Select ALL, Emplgyses‏ 

کے 

sElerTT employee id, TIFCSTtHame , Lastname 

From employees 

COFCAeErT BY Lastname, TIFCSTEHaAE 


4 | ıı 


| FÊ" Messages 


LE ormma ri la) ZCompleted auccrceasfFully 
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بعد ذلك قم بعمل تنفيد للاجراء execute‏ عن طریق الاستعلام الکالی: 
execute sp_Select_All_ Employees 1‏ 
وقارنها بالنتيجة التي ظهرت سابقا لترى العمود الجديد الذي تمت اضافته عن طريق التعديل كما بالشكل:٠‏ 


7 قر 
2 ب“ 


إا 
1 
N‏ 
n#I‏ 
| 


IDF + | F Fxecute 


1pshots 


SfEzecute sp Select A11 Employees ۰ 


_Applicatıons 


TempDB 

AIDF 

: Diagrams 

m Tables 

-ateqorles 

-uSstomerLustomerD 

-uSstomerDermograpF 

-WUStOMErS 

:mployees 

:mployee Territories 

Jrder Details 

Jrders ت‎ 

i'rorurts lastname 

legion |1 3 ; Steven Buchanan 

e 2 EEE 

Nuppllers |3 أ‎ Nancy Davalio 

rerritorlEes 4 3 Anne Lodswarth 
)ا‎ 2 Andrew Fuller 

6 7 Robert king 

mabılıty 5 3 Janet Levering 

roker E Margaret Peacock 
|3 6 Michael  Suyama 


ہے 


| (local) (10.50 RTM) | KSA-DEV-Q001\H 


Query executed successfully,‏ ا 


لفهم ماحدث «فاننا قمنا باضافة الاستعلام ALTER PROCEDURE‏ مأحو قا باسم الإجراء المراد تعديله › ليقو م بعمل تحديث له 
Alter procedure sp_Select_All Employees‏ 
كما قمنا بعمل ترتيب للعناصر باستخدام 0R EDER B۷‏ تصاعديا حسب الإسم الأخير عصهہ یھ[ ثم الإسم first name‏ . 


order by lastname,firstname 
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wlتعرIض SP Definitions‏ 
يوفر 9Q1 SER ۷ER‏ آلية لاستعراض التوصيف الخاص بالعناصر المنشئة في قاعدة البيانات .Definition of Objects‏ 
ویعرفی هذا بعمابة metadata retrieval‏ ,تخزن كافة المعلومات المتعلقة بعناصر قو اعد البيانات فی اجراءات مُخزنة تابعة 
لنظام قواعد البيانات › والتي تمكنك من استرجاعها وقتما تشاء. 
لنقو م بتجربة مثال على ذلك: 
اک تستعرض توصيف الإجراء السابق sp_Select_All_Employees‏ قم بكتابة الاستعلام الال : 

Execute sp_helptext 'sp_Select_All_ Employees’ 
Result to -> Result to text اخڌر‎ مۃ‌û‎ query قبل آن تنفذ الاستعلام › اذهب الى القائمة‎ 
لترى النتيجة كما بالشكل:‎ 


Juery Project Debug Tools Window Lommunity Help 
EE EES 
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Execute sp helptext 'sp Select Al] 
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: Snapshots ر‎ 


nse_Appliıcations 

yer چ‎ 

rwerlempDB 

YIND.MDF 

Jase Diagrams 

5 

stem Tables 

bo.lateqorles 

bo. LustomerL_ustomerl 

bo._ustomerDemograpF 

bo. Lustomers 

bo.Employees 

bo, Employeel[ erritorles 4| IT 
bo. Order Details - 
bo. Ûrders 
bo.Products 
bo.Region 


11 


3 Results 


Text 


CREATE procedure sp Select All Employees 
bo. Shippers ر‎ 


bo Suppliers alert employeeild, Firstname, lastname 
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: oGEdeErE Ey lastname, Fircatname 
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لفهم الاستعلام السابق » فان السر یکمن في الجر sp_helptext)sl‏ ( الممخزن e‏ فی إجراءات نظام قواعد البيانات 
Predefined SQL Server SP‏ و الى تأاخد اسم العنصر (الإجر اء( المراد اظهار ال و0نانمت؟مل له. هذا الإجراء المُخزن 
sp_helptext‏ 5 يعمل غا الجداول فلا تستطيع استعراض عناصر جدول عن طريقه. 
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إعادة تسمية $۲ 
يُمكنك اعادة تسمية اجراءاتك عن طريق استخدام الإجراء المُعرف مسبقاً ءسه«هإ_مء لتتعرف على ذلك تابع المثال التالي: 
أدخل الاستعلام التالي فى نافذة الاستعلامات : 
Execute sp_rename 'sp_Select _All Employees’, 'sp_Select_Employees_Details'‏ 
تم اضغط ما{ںء٥×ع‏ لترى الرسالة التالية فی افده النتائج : 
“Caution: Changing any part of‏ 
an object name could break scripts and stored procedures.”‏ 


على الرغم من نجاح تنفيذ الاستعلام السابق ! » ولتتأكد من ذلك قم بعمل استعراض للاإجراء الذي أنشأناه عن طريق توسعة 
شجرة قاعدة البيانات dمwiطااNo‏ تم توسعة الفر ع Programmability‏ ڌم Stored Procedures‏ ثم كلك یمن واختر referesh‏ 
ستلاحظ أن الإجراء السابق المسمى sءعع0y٬‌اsp_Select_A11_Emp‏ قد تغير اسم sp_Select_Employees_Details Jll‏ 
كما بالشكل التالي: 


File Edit View Project Debug Tools Window Community Help 
ف ف | شا | وع ع ل‎ | | E 5 و‎ 


ı Object Explorer e Î Ql Query3sql - OONHossam GDF ٌ 
| Connect” @Y, 4 F3 7 | Execute sp rename "3p Select All Employees", 's3p Select Employees Details!" 
51 7 (local (SQL Server 10.501617 - KSA- 


El [| A ÛUatabases 


a lJ NORTHWIND.MDF 
EH lA Database Diagrams 
AH lA Tables 
EH LA Views 
EH A Synonyms 
E] lA Programmability 
E Û Stored Procedures 
Fl lJ System Stored Procedures 
A Êl dbo.CustOrderHist 
EH Êl dbo.CustOrdersDetail 
| Î dbo. CustOrdersOrders 
| Ê] dbo.Employee Sales by Country 
| Î dboSales by Year |. ل‎ | 
1 dbo. SalesByLategqory 3 Results 
| Î dbo.sp_Orders_By_Employeeldd 


EH 


ج ج 


e 


اګ 


Caution: Changing any part of an object name could break scripta and stored procedures _ 
| 


اجا 


| Î dbo. Ten Most Expensive Products 
E Êl) dba.ttDeleteProduct 
E LA Functions 


+ 


[I Database Triggers 
1| DA Assemblies 

| Cd Types 

EH Ûd Fules 


+ ]+ 


3 


اشاق ا ا | و او ا ف Query executed successfully. (local) (10.50 RTM)‏ ف 


E Curtpurt | 
Ready 


قام الإجراء المخزن مسبقا مصهمه_مء بتغيير اسم العنصر القديم عن طريق اسناد اسم جديد كما رأينا فى الاجراء السابق › 
ومن مزايا هذا الإجراء انه يعمل مع كافة العناصر سواءا أكانت جداول أو أعمدة ..الخ. 
كيفية استعمال 5۲ داخل أكواد ٥#‏ 
Sp_Select_Employees_Detaıils‏ . 
قم بفتح مشروع جدید من النو ع nہoناھicاpمA Conso1‏ وقم بتسمیته ٥Ca118p1‏ 
ه قم بتسمية اذأف Program.cs‏ نى Cal1lSp1.cs‏ 
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٣ه11]؟pم1.عو قم بنسخ الكود التالي فى الملف‎ 
using System; 
using System.Data; 
using System.Data.SqlClient; 
namespace CallSp1 


{ 
class Callsp1 


{ 


static void Main() 
{ 
// create connection 
SqlConnection conn = new SqlConnection("server=.;integrated security = true;database = 
northwind.mdf"); 
try 
// open connection 
conn.Open(); 
// create command 
SqlCommand cmd = conn.CreateCommand( ) ; 
// specify stored procedure to execute 
cmd.CommandType = CommandType.StoredProcedure; 
cmd.CommandText = "sp_select_employees_details"; 
// execute command 
SqlDataReader rdr = cmd. ExecuteReader(); 
// process the result set 
while (rdr.Read()) 
{ 
Console.WriteLine( 
OPE 
, rdr[0].ToString().PadRight (5) 
, rdr[1].ToString() 
, rdr[2].ToString()); 


rdr.Close(); 


} 
catch (SqlException ex) 


{ 
} 
finally 
{ 


ُ 


Console.WriteLine(ex.ToString()); 


conn.Close(); 


قم بتنفيذ الكود السابق بالضغط على ۴5+[ء)] لترى النتيجة كما بالشكل: 
Î E CAWindows\isystem 3emid cr oo o. 5 .‏ 


SEELEN Buc hanan 
Laura Callahan 


Hancy Davo lio 
Anne DodsıroFrt bh 
AndlFerıs Fu [1] ler 
Ro bert King 
Manet Lever ling 
Par qar et Peacock 
PMic hae 1 Suyama 
Fests any key to continue . _ 
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لشرح الكود بأعلاه لاحظ التعليق مدص رهء ءءء // وأسفله الكود المسئول عن انشاء الأمر الدي من خلاله سنستد عي 
الإإجراء الذي انشأناه في قواعد البيانات sئoyees_detaاsp_select_emp‏ لهذا قمنا بتخصيص عeمd.typ conan‏ 
r ype.StoredProcedure‏ andصc0mm-‏ وقمنا باسناد اسم الإجراء الى 1٥×٤‏ 24ص صه٤.4وء»‏ وبعدها قمنا بتنفيذ هذا الإإجراء 
عن طريق الاأمر S]DataReader rdr =cmd. Execute Reade);‏ » أما باقي الكود فهو لتنظيم عرض ناتج الإجراء السابق. 


لنجرب مثال أخر على كيفية استدعاء إجراء يحتوي معاملات ءإءامء 4مم : 
قم بفتح مشروع جدید من النو ع ہoناھicاpمA Conso1‏ وقم بتسمیته p2؟a11٥‏ 
ه قم بتسمية الملف وع.صوإعٍهإ" الى ءCa11Sp2.c‏ 
ه قم بنسخ الكود التالي إلى الملف وع.2م118و٣°‏ 


using System; 

using System.Data; 

using System.Data.SqlClient; 
using System.Text; 


namespace CallspZ2 


{ 


class Program 


{ 


static void Main(string[ ] args) 
{ 

// create connection 
SqlConnection conn = new SqlConnection(@" 
server = .j 
integrated security = true; 
database = northwind.mdf 
"(5 
try 
{ 
// open connection 
conn.Open(); 
// create command 
SqlCommand cmd = conn.CreateCommand( ) j 
// specify stored procedure to execute 
cmd.CommandType = CommandType.StoredProcedure; 
cmd.CommandText = "sp_orders_by_employeeid2"; 
// create input parameter 
SqlParameter inparm = cmd.Parameters.Add( 
"@Qemployeeid", SqlDbType.Int); 
inparm.Direction = ParameterDirection. Input; 
inparm.Value = 2; 
// create output parameter 
SqlParameter ouparm = cmd.Parameters.Add( 
"@Qordercount", SqlDbType.Int); 
ouparm.Direction = ParameterDirection.Output; 
// create return value parameter 
SqlParameter retval = cmd.Parameters.Add( 
"return_value", SqlDbType.Int); 
retval.Direction = ParameterDirection. ReturnValue; 
// execute command 
SqlDataReader rdr = cmd. ExecuteReader(); 
// process the result set 
while (rdr.Read()) 
{ 

Console.WriteLine( 

OF EF 

, rdr[0].ToString().PadRight (5) 

, rdr[1].ToString()); 
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J} 
rdr.Close(); 


// display output parameter value 
.WriteLine( 

"The output parameter value is {0}" 

, Cmd.Parameters[ "Qordercount" ].Value); 

// display return value 
.WriteLine( 

"The return value is {0}" 

, Cmd.Parameters[ "return_value"].Value); 


} 
{ 
} 


( ex) 


.WriteLine(ex.ToString()); 


conn.Close(); 


ه قم بتنفيذ الكود بالضغط على ۴5 +[ٍء لتشاهد كما بالشكل التالي: 


E CN Windowsisystem32\cmd.exe س نلعاو اکم‎ 


ERNSH 

WAFFE 

RATT 

FOLKÛ 

WI LMEK 

GODOS 

REGO 

ROMEY 

LINÛD 

SANTG 

OTTIK 

KOENE 

WHITE 

SUPRD 

COMI 

PICCO 

RICAR 

FRANS 

LEHMHS 

PERIC 
The output parameter value 1s hb 
The return value is hb 
Press any key to continue . . _ 


كما بالكود السابق «قمنا بإنشاء الأمر الذي يستدعي الاجراء من قاعدة البيانات › وقمنا بتنفيذه بالآلية السابقة » الذي يختلف هو 
الإدخال pû « ParameterDirection.Return Value gy ParameterDirection.Input /Output gIرڙخ! gl‏ قمنا باسناد القيمة )2( 
display output parameter value‏ // 
Console.WriteLine(‏ 


"The output parameter value is {0}" 
, Cmd.Parameters[ "@ordercount" ].Value); 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


// display return value 
Console.WriteLine ( 
"The return value is {0}" 
, Cmd.Parameters[ "return_value" [].Value 
J); 
command بامكانك أن تنشيء أي عدد مں معاملات الإدخال والإخراج كما تشاءِ › کما انوه کے حتمية اسناد معاملات الكود‎ 
.لع؟هاإt إلى معاملات الادخال التي لا تحوي قيم افتراضية وعں ام۷‎ ممrمص‎ 
كما انوه على انه ليس عليك أن تسند معاملات الكود إلى أي معاملات إخراج لن تستخدمها » كما يجب أن يكون اسم المعامل في‎ 
أو‎ capital الكود مناظر لإسم المعامل کک قاعدة البيانات ا کان ادخال او اخراج (لا تعر بالا اذا کان هناك أحرف کبيرة‎ 
أما القيمة المسندة للمعامل ت‎ ¢ (Case Sens1itive لست حساسة لحالة الأحرف‎ T-SQL صعیر ]2او في اسم المعامل ا‎ 
الكود فأنت حر اختيار اي اسم تشاء لها.‎ 
وأحدة‎ return value ةدiعE من وجود قيمة‎ bl الا أنه‎ cADO.NET و الرغم من قابلية معالجة معاملات الاسناد داخل کود‎ 
. حتمية. كما في معاملات الإخراج فإنك لست بحاجة لإنشاء معامل كود لإسترجاع قيمة مالم تنوي استخدامها بالفعل‎ 


حذز lإڄڙرlء Deleting Stored Procedure‏ 
في حال استغناءك عن أي اجراء قمت بانشاءه مسبقاً يمكنك بكل بساطة حذفه » سنقوم بحذف الإجراء الأول لنا 
ect_A11_employeesاSe_مs‏ الذي قمنا بتغییر اسمه إلى ء1نھ)۲6_ءعeرهامص٤_ءeعاعS_مء‏ ولعمل ذلك قم الأتي: 
۾ ق بكتاية الاستعلام التالي فی نافدة الاستعلامات في SQL Server‏ 
Drop procedure sp_Select_Employees_Details‏ 


لتري الرJiwة‏ llتılة .(Command(s) completed successfully)‏ 
e‏ قم با ستعر اض قاعدة البيانات Northw1nd‏ كما تعودت ا أتتحث عں الاجراءات اأخاصة بقاعدة البيانات »> ستلاحظ كما 
بالشكل اختفاء الإجراء الذي قمنا بحذفه (لاتنس ان تقوم ڊچھJa Refresh‏ )(: 


س | سے س سس س 


ect Explorer > HH x SQL Query2.sql - (...OO1\Hossam (5 7)*l SQLQuery1.sql = ...-001\Hossam (541) | 
nnect 7 WY UY F3 5 Drop procedure sp Select Employees Details ا‎ 
۳ (local) (SQL Server 10.501617 - KSA-DEV-OODhHoassar # 
E LA Databases 
aH lg System Uatabases 
2 ا‎ Database وسا ل‎ 


i RTHW IN ا‎ 
3 = Database Deaıran 
FH A Tables 
aH Û Views 
A LA Synonyms 


E Ka Programmability 

EI û Stored Procedures 

aH LO System Stored Procedures 

boa. iustrderHist 
dbo. CustUrdersDetaıl ١ 
bo. Lustirdersirders ل ا‎ 
dbo. Employee Sales by Country ا‎ Messages 
dbo.sales by ear Comand is) completed sauccessfFullyg 
dbo.salesByLategory 
dbo.sp_Urders_By_Employeeld#2 
dbo. Ten lost Expensive Products | 
lbo.ttDeleteProc uct 
unıctions 


E 


E3 


+ ۳ F8 


BH B&H FE 


H اج‎ 


اا کا جا 
E‏ 1 1 1 1 1 1 " 


LE 


E 


1L I PBS TREE 
Assemblies 


3 


E Types 
Rules 
TlaF au ltr 


ا ا 1 


2 


E DROP E EEE 
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خاتمة الفصل 


تعلمنا فى هذا لفصل كيفية انشاء الاجراءات . كيفية استدعاءها وتنفيذها . وكذا كيفية التعامل معها من 
خلال لغة البرمحة ٥#‏ ومناداتها باستخدام .۸00.N٤١‏ تعلمنا كيفية مiادlة‏ lالإجرcl Procedure Calling‏ « 
كيفية التعديل على الاجراء والحصول على المعلومات المخزنة عن الإجراء . وكيفية التعامل مع الاجراءات 
التى تحوي معاملات ء۲ءاء٣‏ هد۴ . وكذا إعادة تسميتها وحذفها . في الفصل التاليى» سنتعرف كيفية 
التعامل مع اN×.‏ 


XML استخدام‎ 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


منذ 1996 وقبل الاصدار الأول لبيئة تطوير .N81‏ ولغة ×١1‏ ظهرت بعد عدة تجارب مخبرية » ومن يومها وقد ازدادت 
الاعتمادية على هذه التقنية بشكل كبير في توصيف البيانات وكأداة رائعة لنقل البيانات من خلال الإنترنت » وعليها قامت 
مايكروسوفت بإدراج امكانيات 1× في كافة منتجاتها. 

هدفنا في هذا الفصل تعريفك على هذه اللغة الرائعة في التعامل مع البيانات مع 2008 MS SQL Server‏ 


في هذا الفصل سنتعلم الآتي: 
تعریف XML‏ 
لماذا xML‏ ؟ 
ه مزايا تخزين البيانات على صورة ×XM1‏ 
e‏ تعر XML documents JİE‏ 
تعرف على llتصرڍıح XML Declaration‏ 
ه تحويل البيانات العلائقية إلى [اM×‏ 
كيفية تخزین واستر جاع اص uءەd M1‏ باستخدام أنواع نٽ XML‏ 
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XML تعريف‎ 

SGML Standard Generalized وهي اشتقاق من اللغة القديمة‎ e×Xtens1bاe‎ Markup Language هي اختصار ل‎ XM 
ءلغات التو صيف لا تستخدم في فى البرمجة » ولكن تسند الى لغات‎ metalanguag وهى تعتبر لغة تو صڍ‎ (Markup Language 
رل ضمت انض رة ال بتقديم وسيلة تمييز أكثر‎ «markup language أخرى لتزيد من امکانیاتها ¢ وهي لغة ترميز‎ 
مرونة ومواءمة.‎ 

تتكون وثائق ۷1× من اسطر نصوص مقروء بالعين وكذا مفهومة للحواسب › كل وثيقة 1× هو كيان لغوي مستقل مُعرف 
باستخدام عناصر (ءار م ه[ء) حيث تقوم الكلمات المفتاحية للغة 1× المعجم الداخلي رإهاuطهءه۷‏ لها بالتحقق من هذه الوثيقة 
من حيث بنية الجملة المكتوبة Syntax‏ ودلالتها XML Schema Definition Language (XSD) رڊizîy Semantics‏ ھي 
المسئولة عن تحديد هذا المعجم. 

في العام 1996 قامت منظمة الشبكة العنكبوتية )W30(‏ بتطوير لغة 1× أملاً في دعم نطاق واسع من التطبيقات» ثم قامت 
باستخدامها في انشاء اللغةَ M1‏ 11× ومنذ ذلك الحين وهذه المنظمة مزمعة بانشاء عدة تقنيات ذات اعتمادية على ]×× بشكل 
واسع منها Language )×S1(‏ esheetاSy‏ eاe×tensib‏ » وهي لغة جيدة في اضفاء صفات جيدة لتصميم صفحات الويب كما في 
اللغة Cascading Style Sheets (CSS)‏ المشهو رة مع اHTM‏ › وکذا طو رٽ غ (XSLT) XSL Transformation‏ < gو‏ تى 
تقوم بالتحويل فيما بين وثائق 1> المختلفة. 


اذا XML‏ ؟ 

تعتبر ۷1× لغة متعددة الأغراض > واسعة الاستخدام في تقنيات تمثيل البيانات المختلفة وكذا التطبيقات المختلفةء كما أشرنا 
بأن قواعد البيانات العلائقية من ميز تها انها تتعامل مع البيانات مهيكلة لع إں)ءںم )وء فان لغة 1“×× تتميز بأنها تتعامل مع 

البيانات structure‏ سء والغیر مھیلكة بالمرة لع kuc kur‏ یءہں › کما انها ذات تكامل تام مع نظام قواعد البيانات SQL e‏ 
8 وما قبله »فتمكنك من استخراج البيانات والتعامل معها وكذا التحويل بينها وبين قواعد البيانات العلائقية. 


مزايا تخزين البيانات على صورة ×XM1‏ 
لا تعتمد 1× على طبيعة النظام التي تعمل عليه platform-1ndependent‏ > كما أنها توفر مرونة عالية لا تتوفر فى قواعد 
البيانات العلائقية في بعض حالات عرض البيانات » إلا أننا يمكننا حصر هذه الميزات في التالي: 
ه بما أنها لغة ذاتية التوصيف عم 1طإءءمل-۴[ءء فيمكن للتطبيقات التي تعتمد عليها أن تتضمن بيانات 1× من معرفة 
البنية او التوصيف لهذه البيانات : ویتم تضمينها في صورة شجرية تنقسم الى جذر Root‏ وکذا فرع رنيسي Parent‏ 
ەلە وهذه الصورة تكون مايعرف بوثيقة .×M1‏ 
ه الطريقة التي تكتب بها 1× تحافظ على تنسيق محتواها لأنها دائما في صورة شجرية منظمة. 
٠ه‏ يتم التحقق من صحة أي وثيقة 1× عن طريق .XML Schema‏ 
ه الطبيعة الشجرية المرتبة للغة 1× » تمكنك من البحث بداخلها عن طريق استخدام أي من لغات الاستعلام والبحث 
داخل ]۷× مثل .XPath gs Xquery‏ 
ه بما أنها لغة ممتدة م[طزومم)×م » فمن السهل إجراء عمليات قواعد البيانات المعتادة عليها من اضافة وحذف وتعديل. 
بالطبع هناك الكثير من المزايا » كما أنوه على أنك كلما كتبت وثائق 1× حسب الطرق القياسية المعتمدة من منظمة مثل 
۷3° كلما استفدت بمز ايا هذه التقنية. 


تعرف على وثائق ×M1‏ 

من الممكن ان تكون وثيقة 1× في صورة ملف مُخزن على الكمبيوتر › أو فيض بيانات عبر الشبكة stream‏ ta۾d‏ (في 
الحقيقة نظرياً يمكنك أن تقراً هذه البيانات عبر الشبكة › > لكن في الواقع تكون هذه البيانات مضغوطة في صورة ثنائية رءهم81)» 
كما أنها من الممكن أن تكون سلسلة نصية ثعالج في ذاكرة الحاسب » يجب أن تكون رصينة المحتوى متكاملة في المعنى حتى 
بدون ا مصعطء؟ فحتما ستتبع قواعد معينة في كتابتها > حتى في بساطة الوثيقة المكتوبة أيأ كانت » يجب أن تتبع قاعدة عامة 
في غلق كافة ال فروع (i1sطء)‏ قبل أي وسم (tag)‏ رئيسي (parent)‏ < > على سبيل المثال تعتبر الوثيقة التالية منسقة تماما 
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<states> 
<state> 
<name>Dakahl1</name> 
<city>Mansoura</c1ty> 
<city>Belqas</city> 
</state> 
</states> 
يحوي العنصر وعءاه)ء موضوع بين الوسم <وم)هيء> وانتهى بالوسم <ومع)ه)ء/> › هذا هو مانسميه‎ )٠۵۲( فكما ترى الجذر‎ 
XML العنصر الرئيسي ٥م للعنصر الفرعي م)ه)ء الذي بدوره يعتبر اروم للعنصر مءصهم والعنصرين راا أي ثي‎ 
واحد فقط » ربما تجد بعض العناصر تحتوي على خصائص وءءاںطزع))ه » ففي المثال التالي تم وضع‎ ٠٥۲ تحوي عنصر‎ 
خصيصة عروهم للعنصر ع)اهاء:‎ 
<states> 
<state name="Dakahl1"> 
<city>Mansoura</city> 
<city>Belqas</city> 
</state> 
</states> 
أي عنصر يُمكن ان يحتوي عدد لا محدود من الخصائص شريطة ألا تكون هذه الخصائص متكررة » فمتلا العنصر راء لن‎ 
يتم وضعه كخصيصة هنا لأنه متكرر مرتين لمدينتين فالأحرى وضعه داخل وسم كما في المثالين أعلى > کما أنه قد يحتوي‎ 
على بیانات (نصوص أو حتى عناصر أخرى) أو قد يكون فارغأ يعني يبدأ ويغلق الوسم دون فروع (</.......>)» مثال على‎ 
أك اذا أردت أن تعرف عدد الأمحافظات › يمكنك استخدام عنصر فارغاً ليحل لك هده المسألة.‎ 
<states> 
<controlinfo count="1"/> 
<state name="Dakahli"> 
<city>Mansoura</city> 
<city>Belqas</city> 
</state> 
</states> 


کما تلاحظ العنصرالفار ع controlinfo‏ يحوي خاصية واحدة فقط count‏ لکن پلا e‏ > لأننا بدانا الوسم وأغلقناه ی نفس 
سطر العنصر </"1"=اcoun‏ oگinاcontro>‏ ویمکن أيضاً تمثيل هذا الو سم بهذه الطريقة: 


<controlinfo count="1'"'> </controlinfo> 


على الرغم من سهولة تصميم وثائق 1× » إلا أنه يحتاج بعض الجهد كما تصمم قواعد البيانات. 

بعص مصممي XML‏ لايتفقون علي أهمية الخصائص attr1butes‏ اذ يمكنك الاستعاضة عنها بالوسوم كما رأينا (وبالتالي إن لم 
تظهر لها اهمية فلن يكون هناك أهمية للعنصر الفارغ ككل) › ولكنهم يرون أنها تشبه في هذه الحالة قواعد البيانات العلائقية 
على کل حال لا يعني هذا أن الخائص لن تجد لها مكانا في تصميم وثيفة 1× فليس مطلوبا من 1× أن تطابق كافة 
خصائص قو اعد البيانات العلائقية. 


XML Declaration ڎ@م‎ 

في حالة أردت أن تتعمق فى تطوير تطبيقات ۷1× فانت لن تتوقف على استخدام العناصر والخصائص وفقط » فإذا أردت ان 
توافق معايير ۷3٥‏ عليك أن ٿتضaَj XML Declaration‏ في وثيقة ال_1"× ومكانها يقبع أعلى العنصر الجذر root element‏ 
في وثيقةَ .×M1‏ 

طريقة كتابة ال و0ناهءه1ءء متل كتابة العناصر لكن مايميز ها أننا نضع علامة استفهام بجوار فتحة الوسم » وتحوي الخاصية 
version;‏ والتي تمثل بالقيم 1.0,1.1› ولتوضيح الطريقة األى تکتب بها انظر التالى: 


<? Xml verslon="1.0" ?> 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


هناك الكثير والكثير من الخصائص التي تمتلكها 1× لكن ما ذكرناه آنفاً هو كاف لتبداً معها » فكما رأيت لم نستخدم أي 
تصريحات خاصة باللغة او schemas‏ أو namespaces‏ < والمتال الذي طر حناه ھو متال متکامل بمكننا فيما بعد التعديل 
والاضافة عليه ليصبح مثالا حقيقياً. 


تحويل البيانات العلائقية إلى اXM×‏ 
استخدمنا الاستعلام S٤1 ٤٣1‏ لكي نعود بقيمة عمود ما في قاعدة بيانات ¢ يمكننا أن نسترجع قيمة استعلام مكتوب بال ام؟ 
الي 1× وذلك عن طريق الاستعلام ×M1‏ ۴0۸ بإضافته الى الجملة SELECT‏ › وعن طريق 2008 MS SQL SERVER‏ 
نستطیع زيادة قدرة هذا الاستعلام والحصول کا نتائج لإستعلامات معقدة بز يادة قدرة الاستعلام عن طریق الكلمات المفتاحبة. 
یستخده الاستعلام ۴0٥R XML‏ اتحویل النتائج من الاستعلام العادي الى بنية 1× › وتوفر أربعة أنماط لذلاك٠‏ 
FOR XML RAW‏ 
FOR XML AUTO‏ 
FOR XML PATH‏ 
FOR XML EXPLICIT‏ 


:FOR XML RAW Yg 

يستخدم هذا النمط لتحويل كل صف في الاستعلام العادي الى عنصر “× » هذا العنصر يعرف كصف في ناتج الاستعلامء 
وکل عمود يتم الاستعلام عنه بجملة SELECT‏ يتم تو صیفه کخاصیۂ ۸1۲۸1811۴ داخل عنصر هذا الصف > يحدث هذا مع 
الاعمدة التي لا تساوي 1ا"×. 


جرب هذا المثال: 
e‏ افتح MS SQ1 Server‏ كما تعودت. 
۾ في مستعرض العناصر قم باستعراض قواعد البيانات عندك واختر قاعدة البیانات ۲W ٥k‏ ں) ہ٥۸۷‏ ثم كلك یمین 
yاختڙر .New Query‏ 
م أدخل الاستعلام الى « تم أاضغط تنذفيذ٠‏ 
SELECT ProductModellD, Name‏ 
FROM Production.ProductModel‏ 
WHERE ProductModelID between 98 and 101‏ 


FOR XML RAW 
¢ لترى النتيجة كما بالشكل › عبارة عن رابط في نافذة النتائج‎ 

I. ۵‏ ا : م5 ق e‏ ا e‏ 5 ڪڪ 
XML_F52E2861-1...805F49916B1.xml _* SQLQuery1.sql - (...-O01\Hossam (54))*| >‏ ` ات تت plorer‏ 

ٍ ل‎ E] SELECT ProductHodelID, Hame ا‎ 
EEE SE LSE SE GE EAGT FROM Production. ProductHode 1l ا‎ 
E E WHERE ProductModelID between 98 and 101 
J Uatabases FOR ¥MT RAW 


J LJ System Databases 

1 lJ Database Snapshots 

1 lJ aspnetdb 

1 ا‎ LivilDefense_Applications 1 
1 lj NORTHWIND.MDF 

1 lJ ReportSeryer 
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1 lJ ReportserverTempDB 


1 ۳ AdventureWorks کا‎ ۳ 
IF lJ Database Diagrams Î Results ۴۳ Messages | 
mH lg Tables XML_F52E2B61-18A1-11d1-8105-00805F49916E 
aE a ROD ا‎ EEE EEE 


Hl i Synonyms Sassen ّ 


E LA Pragrammability 1 
A LJ Sersice Broker : 
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اذا ما ضغط عليه ستری التالي: 


ع اب چت اچ 2 2 طا ب 1 کا كھ 
FX‏ ا | )54( Object Explorer y ll X  /XML_FS2E2B61-1...805F49916B1.xml | SQLQueryl.sql - (...-001\Hossam‏ | 
آ_ }/ Connert™ a | row ProductMode1 ID="98" Hame="Chain"‏ | 


: row PFroductHodelIl="100" Name="HL Crankset" ;/? 
| 


a row ProductHodelID="101" Name="HL Crankset" أ‎ 
EH İl System Databases 
EH A Uatabase Snapshots 
E lJ aspnetdb 
3 ۲ LivilDefense_Applications 
E | NORTHWIND.MDF 
ا‎ ۲ ReportServer 
3 آ‎ ReportSeryerTempDE 
@ |j AdventureWorks 
E LA Securrty 
E lA Server Obpects 
E LA Replication 
# LA Management 
0 SL Server Agent (Agent APs disabled) 


I1 


كما أسلفنا في شرح وظيفة هذا الاستعلام فإنه كما رأيت يقوم بتحويل صف الاستعلام المعتاد إلى صف في وسم ال [اM×‏ 
ءثم قام بالاستعاضة عن القيم التي كانت ستظهر فى الاستعلام العادي الى خصائص » باستخدام الأسماء المستعارة ويهنا۸ 
مه التي حددناها فى الاستعلام ٬لينتج‏ مصفوفة من العناصر كما رأيت بالشكل ٠‏ لا يمكن بحال أن نسمي الاستعلام الناتج 
على أنه وثيقة ۷1× فلو تذكر أنه لكي يكون عندنا وثيقة ۷1× فإنه يلزمها عنصر واحد يعمل کجذر ۰٥۵۲‏ وهو مالا يتوفر 
فى الاستعلام السابق. 


جرب المثال التالي أيضاً: 
في المثال السابق » كان التركيز على الخصائص وءاںطن))ه في المثال هذا سيتم التركيز على العنصر امعم ء]م » مما يعني انه 
سيتم انشاء عناصر جديدة لكل عمود في الاستعلام » ولعمل ذلك لابد من اضافة الكلمة المفتاحية 18 ۸غ٤ E]‏ بعد الاستعلام 
FOR XMا RAW‏ كما في المثال: 

ه نفذ الخطوات السابقة لعمل استعلام جديد 

ه قم باضافة الاستعلام التالي > ثم اضغط ۳۴5: 


SELECT ProductModellD, Name 

FROM Production.ProductModel 

WHERE ProductModellD between 98 and 101 
FOR XML RAW,ELEMENTS 
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لتري كما بالمثال السابق في نافذة النتائج رابط » قم بالضغط عليه لترى كما بالشكل: 


lz Microsoft SQL Server Management $ 
File Edit View Project Debug #XML Tools Window Lommunity Help 
Û New Quey | dı | È BÈ ® |B | F A&R 
EEE 2 3k | =| 2 2| LE 
EEE BREE WT | /XML_FS2E2B61-1..805F49916B2.xml [ SQLQueny1.sql - (..-001\Hossam (4)) | 
Connect” f? E] xrowz ا‎ 


| #ProductHode 1ID*984<,/ ProductHode 1 ID 3 


= lû (local) (SL Server 10.20.161 - KSA-DEV-OOD Hossam] 
E CA Uatabases 
FH J System Databases 


#Wame w»Chain<t 7 Hame x 
+ j POW 


E <row> 

IH Û Database Snapshots <PraductMode11D>99</ProductModelID> 

J aspnetdb | Name LL Crankset<t Hame 

lJ CiwilDefense_Applications 4 TOW 

& lJ] NORTHWIND.MDF EH trou 

۲ ReportSeryer #ProductHode 1ID*1004/ ProductHode 1 ID 

U RepaortServerTempDEB | Hame zHL Cranksets /Namez 

Hl ۲۳ AdventureWorks f FOWZ 
@ KA Security E] xrowz > 
mH A Server Objects 4ProductHodelID>101</ProductHodelIDY 
f Replication | #Namez»HL Cranksets Hame 

4 yî OW 


EH KA Management 
SL Server Agent (Agent XFs disabled] 


کما رآیت فو ضعك للكلمة المفتاحية N18‏ چغ E1‏ بجوار الاستعلام FOR XML RAW‏ هي كلمة السر کی تبدل الناتج عن 
(centric‏ ¢ وهي ايبضا كسالفتها لم تو لد وثيقة XML‏ لعدم احتواءها غل .TOOt‏ 


كيفية اعادة تسمية الصفوف 
يمكننا في الاستعلامات السابقة اعادة تسمية الصفوف الناتجة »› عن طريق وضع خصائص اختيارية للاستعلام السابق > كما في 
المتال الى > سنضع اسماء مستعارة للصفوف في الlتعںام :FOR XML RAW‏ 
ه قم بالكتابة فوق الاستعلام السابق بوضع الاستعلام التالي محله واضغط 1۴ €١ا٤٣E٤E×E٤:‏ 
SELECT ProductModelIlD, Name‏ 
FROM Production.ProductModel‏ 


WHERE ProductModelID between 98 and 101 
FOR XML RAW (‘ProductModelDetail'"), ELEMENTS 


ه لترى رابط في نافذة النتائج بالضغط عليه ترى نتيجة كما بالشكل التالي: 


_ KML_FSZE2B61-1...805F49916B3.xml | SQLQuery1.sql - (...-001\Hossam (54))7 
E #FroducrctEHode [Deta i l1 
4 ProductHode 1 ID»I8E<t7 ProductHode 1 ITDY 


×| ۶ا 


+ Mame w™TChain<t 7 Hame x 
# ProdAuctHode 1Detai l= 
E #FEOAUGEHodE LDeEtATLL* 
ZProductHode 1 TD» 7 ProductHode 1 TD 
| #Mame x*LL Crankset< 7 Hame xw 
## ProductEHode 1Detaaî 1I3 
E £FroduTtEHode 1]DeTtai LF 
# ProductHode l1 ID»100<ل/7‎ ProductHode 1 TD» 
| #MHame zHL Crankset-< 7 Hame 
&# ProductHode 1Detai Ll» 
E Produ TtEHode TDeETa1 lL 
ProductHode 1ID»™101<ل<7‎ ProductHode 1 ID™ 
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Mame xz*HL Cranksets 7 Hame xw 
# # PFoOUTEHode T1Detaiîi lx 
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اذا 2 تضف الكلمة المفتاحبة ELEMENTS‏ للاإستعلام e‏ ¢ فسو ف يتم تغيير الناتج ا e centr1C‏ مع تغییر 


الام و اطا 


<ProductModelDetail ProductModelID='" 98" Name="Chain'" /> 

<ProductModelDetail ProductModelID="99'" Name="LL Crankset" /> 
<ProductModelDetail ProductModelID="100" Name="MLl Crankset" /> 
<ProductModelDetail ProductModelID="101" Name="Hl Crankset" /> 


FOR XML RAW ملاحظات عى‎ 

کما لاحظت فإن الناتج دائما لايكون وثيقة 1> لعدم وجود العنصر الجذري > كما لاحظت اشا ان الناتج إما يكون element‏ 
Yg attribute centric gÎ ‘centric‏ تستطيع أن تحصل على الاثنين معا » كما لاحظت أيضا أن كافة عناصر ۷1× في نفس 
المستوى الشجري لا يوجد .CHILDES gİ PARENTS‏ 


FOR XML AUTO ثانيأ‎ 


تستخدم هده الخاصية لإرجاع استعلام XML‏ متشابكک nested‏ لهذا لن لحك المزيد مں التحكم في الاستعلام الناتج ¢ وتظهر 
فائدتها 8 اذا أردت أن تسترجع متسلسلات hierarch1les‏ بسيطة. 


كل جدول يتم الاستعلام عنه بالجملة ۴۸0۷ وعلى الأقل يتم الاستعلام عن عمود بجملة 5818٥1‏ يتم تمثيله كعنصر 1× › 
اما في صورة عنصر فر عي امع صم اعطںء»ء أو في صورة خاصية عا ںطن))ج . 


مثال عy FOR XML AUTO‏ 
اتبع الخطوات التالية لتنفيذ الاستعلام الخاص ڊ¬ :FOR XML AUTO‏ 
ه قم بفتح نافذة استعلام جديد في قاعد البيانات وه ۷Wءإں)مء‏ ۸۷ وادخل الاستعلام التالي واضغط عااءم×م: 


SELECT Cust.CustomerID, 
OrderHeader.CustomerID, 
OrderHeader.SalesOrderID, 
OrderHeader.Status, 
Cust.CustomerT'ype 
FROM Sales.Customer Cust, Sales.SalesOrderHeader 
OrderHeader 
WHERE Cust.CustomerID = OrderHeader.CustomerlD 
ORDER BY Cust.CustomerIlD 
FOR XML AUTO 
لترى في نافذة النتائج رابط قم بالضغط عليه لترى كما بالشكل:‎ 


File Edit View Project Debug XML Tools Window Community Help 
New Query | i ا اشا ات ت ت‎ 3 


اا چک اھ _ EE E E N aa E‏ ھچ کا ج كا 
ج | )55( Object Explorer TH *& || -KXML_FS2E2B61-1...805F49916E5.xml SQLQuery2.sql - (...-0011 Hossam‏ 
Connect > f ıı kCust CustomerID=™1" CustomerType="S™sy‏ 
DCE CHeader Customer L[UeE™1] SalesÛrderT[E"43B860 StaAtUg=FG™ Fy‏ = 
lî (local) (SQL Server 10.50.1617 - KSA-DEV-OON\Hossam) Orde rHeader CusztomerID="1”" SalesOrderIUD="44501" Status="S™ Fx‏ = 
El Lg Databases ZUDCeE Header Customer I[TE™"™1]1”" SalesÛrderITFF#E"45283" Status=™S™ F>‏ 
El ll System Databases <OrderHeader CustaomerID="1" SalesOrderID="46042" Status="S" 4/>‏ 
FH Lg Database Snapshots 2 FCuUSt=‏ 
EH lJ aspnetdb E <GuaSE CustaomerID="2” CustomerType=" Sry‏ 
ر A LJ Civil Defense_Applications ` zOrderHeader CustomerID="2" SalesOrderID="464765" Status="5™‏ 
aA LJ NORTHWIND.MDF Ire rHeader CustomerID="2" SalesOrderID="479397" Status=™S™ F>»‏ 
ReportSerwer OTe THeader Customer IUD=™z2”" SalesOrderIUD="49054 Statugz=™G™ f»‏ ا El‏ 
E3) 7۳ ReportSerrer TempDE UTE TrHeader Customer IU=rgF™" SalesÛriderITU=E"Sl0Z 16 SEaTtUz="™S™ Fn‏ 
ج Hl ld Arlventurevorles UFC erHeader Customer IUeE"2" SalesÛrderIU="SI1T28" SLtatus=™S™‏ 
ج ™ mE Û Security Ure rHeader Customer I[UeE™7" SalesÛrderIlLE"s'7044 STLEALUg=m ER‏ 
EH Û Server Objerts UrderHeader CustomerID" z2”" SalesOrderIUD="é53138" Status="™S5™ f>‏ 
mH FA Replication ZUFCeE rHeader Customer IDeE™g3" SalesÛrderITUE#E"éiG488" STtatusz=™Ss™ 2‏ 
E A Management ٌ 5 5‏ 
EÊ, SQL Server Agent (Agent XPs disabled] ERASE CESET EUSTORECTTIEE E Û‏ 
UTE rHeadler Customer I[D=™3" SalesÛrderIU="ES5310" Status=™S™ Ff‏ 
ج xUrFierHeader Customer IlID="3" SalesÛrderIU=E"FTI18E0" Status=™S™‏ 
UTCTOe TCHeader Customer lIUl=E™3" SalesÛrder IUFE"53616" STtatus=™g™ 2‏ 


ھے 
_ 
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كما لاحظت فإن الخاصیة 12ہ ہیں تفھرس الجدول یں › لھذا تم انشاء عنصر باسم {وںC‏ وخاصیيۂ م{ ںطا))ج باسم 
CustomerID‏ « أيضاً الثلاثة أعمدة OrderHeader.CustomerID , OrderHeader.SaleOrderID, OrderHeader.Status‏ 

تفھر س الجدول ٠ 0de] ٥ad‏ لهذا تم اضافة العنصر ء٥‏ ]م0 كعنصر فر عي اہع ع1٥‏ طںء للعنصر tوںC‏ وتم وضع 
الأعمدة الثلاثة كخصائص عنص .OrderHeader‏ 

تم أيضا فھر سۂ العمود 12ء ہہ†یںu٤.tوںCu‏ للجدول tوںC‏ والذي کان معرفا بنفس العمود > لهذا لن يتم اضافة عناصر جديدة 
»ول بدلا من ذلك تم اضافة الخاصية CustomerType‏ للعنصر یں الذي تم انشاوه مسبقاً 

يقوم الاستعلام بتخصيص أسماء مستعارة للجداول » تستعمل محل أسماء العناصر› أما ال الاستعلام ORDER B۷‏ فیستخدم 
لتجميع كل العناصر الفرعية مءإل1زطC‏ تحت عنصر فرعي واحد اممإو۲. 


FOR XML AUTO Jiع ملاحظات‎ 

لا ينتج عن استخدام FOR XMا AUTO‏ أى وثيقة 1× لكونها لا ينتج عنها أي عناصر جذرية ومع ]ع ا0ه۲. 

مں الملاحظ أيضا ان الناتج إما ڍكgوjù «element centric‏ أو Yg attribute centric‏ تستطيع ا تحصل على الاثنين معا مٿل 
سابقتها » كما أنها لا توفر خاصية اعادة التسمية كما في FOR XML RAW‏ > ومع هذا فهي جيدة جدا في استخدام انغاء 
الجداول والأعمدة والأسماء المستعاة وموهزاه حال توفرها. 


كيفية تخزين واسترجاع ئر M1 docu me‏ باستخدام أنواع بيlنlٽ XML‏ 

يوفر لنا 2008 Q1 Sever‏ نوع بیانات ممpر۲‏ ه54 جديد هو (1») والذي لم يصمم فقط ليتعامل مع وثائق ۷1× (والتي 
يكفيها ن تتعامل مع نوع البيانات الخرقى character Strings‏ ِد أنه كاف ليحوي اي قيمة حرفية) ولكکن صمم هذا النوع 
ليتعامل مع عمليات وثائق ال 1× المختلفة. 

في حقيقة الأمر عندما يتم ترجمة XML ûãîs Parsing‏ لايعني ن العملية قاصرة على قراءة فقط ¢ ولکن هناك عملية تحديث 
لهذه الوثيقة أيضا (يتم تحويل وثيقة ×M1‏ إلى (DOM tree‏ .. 

ماهي اڵ D0M‏ ؟ 

هي اختصار أ Document Object Model‏ و هي منصة تمكن البرامج والأكواد من تحديث والاتصال بأي وثيقة ]×× ولیس 
هذا فحسب بل العديد من أنواع الوثائق الأخرى HTML Jin‏ أو أي محتوی هيکلي documents‏ tiructuredء‏ عن طریق توفیر 
الأخصائص والكائنات والدوال المختلفة لذلك. 

يُمكننا من اجراء أي تعديل على وثائق ۷1× من تحديث وحذف وإضافة قيم وعناصر من و إلى المتسلسلة الشجرية 
.hierarchy‏ 

ما سنقوم بعمله هو اجراء تحديث باستخدام مءمرا ههل 1س× واما عن طبيعة نوع البيانات هذا ومزاياه فهو خارج اطار الكتاب 
هذا » لأنه يحتاج حقيقة الى كتاب منفصل » كل احتياجنا منه هنا كمبرمج قواعد بيانات هوما يلزمك معرفته لاسترجاع وتخزين 
وثائق .×XM1‏ 


تنوية 

هناك طرق عديدة لإإجراء العمليات المختلفة على وثائق 1> باستخدام ۸50.۴1 وكذلك ]1×۷ SQ‏ (وهي ترقية للاإصدار 
3Q1 Server 0‏ للتعامل مع ۔M1»)‏ کل هذا سیکون جید لو لم يكن لدينا هذه الميزة في 2008 / 2005 SQ Server‏ › ا 
في هذا الكتاب نعطي نبذة وبامكانك الاستزادة اذا أحببت التخصص » فمجر د امكانية كتابة 1× من خلال 1-1 فإنھا تفتح 
امات أفاق وامكانيات متعددة لا حصر لها ولكن اجتهد في البحث وتوظيف ماتعلمته في ذلك. 


جرب هذا المثال لإنشاء جدول لتخزين ×ML‏ 
لإنشاء جدول يحوي وثائق ۷1× » قم بتنفيذ الاستعلام التالي في نافذة استعلام جديدة: 
create table xmltest‏ 


( 


x1d int not null primary key, 
xdoc xml not null 
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.(Command(s) completed successfully.) مIعتlلا لترى رسالة نجاح‎ 


هذا الاستعلام يُشبه الطريقة التي ننشئ بها الجداول في العادة » وعلى الرغم من أن نوع البيانات 1× يختلف عن باقي انواع 
بيانات SQL Server‏ ¢ الا ن طريقة أنشاءِ الجدول وتعریی الا دة هي هي مثلما في ا@S؟ ٤‏ فیما عدا ان xml data type‏ 


.Pri ary Ky لايستخدم كمفتاح رئيسي‎ 


مثال على اضافة وثائق ۷1× إلى الجدول )× 


ه قم بإضافة الاستعلامين التاليين » في نافذة الاستعلامات السابقة » ثم اضغط عانءم×م: 


insert into xmltest 

values( 

1 

<states> 

<state> 

<abbr>CA</abbr> 
<name>Californ1a</name> 
<city>Berkeley</city> 
<city>Los Angeles</city> 
<city>W1lmington</c1ty> 
</state> 

<state> 

<abbr>DE</abbr> 
<name>Delaware</name> 
<city>Newark</c1ty> 
<city>Wı1lmington</c1ity> 
</state> 

</states> 


) 


insert into xmltest 

values( 

2 

<states> 

<state abbr="CA" name="Californla"> 
<city name=" Berkeley'"/> 

<city name="Los Angeles"/> 

<city name="Wı1lmington"/> 

</state> 

<state abbr="DE" name="Delaware'"'> 
<city name="Newark"/> 

<city name="Wı1lmington"/> 

</state> 

</states> 


) 


لتظهر أك رسالة نجاح الاستعلام في نافدة النتائج 1(row(s) affected))‏ ( مر تین ¢ وادا أردت تستعر ضص نتيجة ماقمنا يه › 


فاكتب الاستعلام التالي في نافذة الاستعلامات واضغط ۴5: 
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Select * from xmltest 


لترى في نافذة النتائج عمودين يحوي كل منهما وثيقة 1× » اضغط على العمود الأول في ءم× لترى كما بالشكل: 


ndow Lommunity Help 


A5 Ql‏ 3 1 وا 
xdoc1.xml 5QLQuery3.sql - (...-001\Hossam (5)) | ¥‏ | ¢ 
gtstatess a. E.‏ | 
4statey 1‏ ُ1 
١ tabbr»>CTA+t J abbr>‏ 
4name»California</name Y>‏ 
#CItYZBerkeley<tfcCiItY?‏ 
4CItEYLOS AngelestfcCityr>‏ 
CITY*W1lmington<tf City>‏ 4 
4f atatez‏ 
ZELAL E‏ 
#abbr>DE</ abbr>‏ 
+HaAmeE »DeElaware<t/ name x‏ 
#CItYZNewark</ CITY>‏ 
د ZCITEYZWI Imington< 7 CItYY‏ 
tf statez>‏ 
+f stateszr‏ 


كما رأيت في السابق حين تعاملت مع الجملة N5٤۸7‏ لا يوجد أي اختلاف هنا » قمنا بسناد قيمة المفتاح الرئيسي في عملية 
الادخال .۲ » ووثيقة 1× كمتسلسلة نصية ونتج ما توقعناه تماما. 


خاتمة الفصل 

في هذا الفصل قمنا بتغطية أساسيات ۷1× والتي يستوجب على كل مبرمج #© أن يعرفها . وتعرفنا على 
خصائص وثائق اN××‏ وكيفية التعديل فيها . وكذلك كيفية انشاء‌ها من خلال S66۲‏ ا5۵ .وكما نوهت 
الطريق أمامك الآن مفتوحا للتعمق أكثر وأكثر فى هذه التقنية وكيفية توظيف ذلك في برامجك المختلفة 
ومنصاتك المتعددة من الحواسب العادية الى أجهزة الموبايل » كما تشاء. 
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تلعب العمليات دوراً رئيسياً اليوم في عالم الأعمال لاشتمالها على العديد من الإجراءات والعمليات الأخرى »› وتظهر فوائدها 
جليا في تحقيق تكاملية البيانات راع م)ہ! للعديد من العمليات الأخرى المرتبطة » وعندما يحدث تداخل فيما بين 
المستخدمين أثناء تعاملهم مع البيانات. 
في هذا الفصل سنتحدث عن مبادئ ال ورمن مهیمهإ] وكيفية استخدامها مع 2008 إم۷إمS Q1‏ ولغة C#‏ » وهذا هو المحتوى: 

مlهي‏ آ— Transactions‏ ؟ 

؟Transactioas متٴ iنستJaz |آ—‎ e 

فهم الخصائص ۸٥1D(‏ 

Transactions —| صم‎ e 

Transaction Î ٽڵla‎ e 

تعيين دو |آ— Transactions‏ 

ه ماهي جمل 1-5@1 المسموح بها في آ— Transaction؟‏ 

SQL في‎ )Local Transactions) ıl) العمليات‎ e 

SQL ف„‎ (Distributed Transactions) Aع‎ jgمlا العمليات‎ e 

ه دليلك لكتابة أكواد عمليات فعالة 

ه كيفية برمجة العمليات 

كتابة أكواد للعملیات باستخدام ۸D0.NE1۲‏ 
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ماهي | Transactions‏ ؟ 

هي مجموعة من الإجراءات والعمليات ثنفذ كحزمة واحدة » فإما تنجح بالكلية أو تفشل بالكلية. ويعد أشهر مثال لها هو عملية 
تحويل الأموال من الحساب الجاري إلى حساب التوفير في البنوك > فهذه العملية تطلب اجرائين: 

الأول عملية خصم الرصيد من الحساب الجاري » والثاني إضافة المبلغ إلي حساب التوفير > لذا لابد من نجاح العمليتين مرة 
واحدة وإلا فسوف يحدث عواقب وخيمة يترتب عليها خسارة الناس لأموالهم › أو في حال الفشل لأي طارئ لاقدر الله يتم 
تدارك الأمر بايقاف كلا العمليتين و کان شیئاً لم یحدث عن طر يق استخدام ال وره نامووم ه1۲ » فمنتهى العملية إما ضمان نجاح 
اله اورف ا جره هما فل لت مع وور ات لرن ا مات كاه دون ر 


متی نستعمل |آ— Transactions‏ ؟ 
كما تبين من مثالنا فأفضل استعمال لها حينما نريد ضمان نجاح او فشل أكثر من عملية كوحدة واحدة › الأمثلة التالية توضح 
بعض سيناريو هات استخدام ال وو م1اTransac:‏ 
e‏ ف حالة معالجة الدفعات batch processing‏ حینما نرید ادخال أو تعديل أو حذف أکثر من صف دفعة وأحدة, 
ه في حالة أي تغيير على جدول يتطلب بقاء الجداول الآخرى كما هي. 
ه حينما نريد التعديل على أكثر من قاعدة بيانات بشكل متزامن. 
e‏ کی حالة العمليات الموز عة على أكثر من قاعدة بيانات على أكثر من خادم .Dıstr1buted Transactions‏ 
وقت اجراء هذه العملية › فان قاعدة البيانات بضاف اليها قفل )عه] ¢ مما يجعل اجر اء أي عملية أخرى لے قا عدۃ البيانات غير 
ممکن › ممكن » الى أن يتم رفع هذا القفل » عملية القفل هذه تبدأ من قفل للصف إلى قاعدة البیانات کلها. تسى هذه العملية بالتزامن 
کک e‏ ا ت مل ع قاعدة ت في نفس LL‏ 
و فکلاهما قد بفقد. 


استخدامك للعديد من الأقفال قد يوّثر بالسلب على أداء قاعدة البيانات › لهذا يُفضل تعليق قاعدة البيانات من أجل ال 
ئ5ااeهءمهr)‏ يتم في مدي قليل من الزمن تجنبا لهذه المشكلة. 


فهم الخصائص ۸٣1(‏ 
هناك أربعة خصائص لل ورهنامهوم و تختز ل فى الكلمة ۸٣1۲‏ وهي : 
الذدرية Atomicity‏ 
الثباتية Consistency‏ 
Isolation Jjall‏ 
llبقlأıة Durability‏ 
مادا یعنې کل هذا ؟ 
e‏ يعتبر آ— transaction‏ ف الخاصية Atomıicity‏ حدثاً مستقلاً single action‏ وليس دفعة من العمليات المنفصلة »› لذا 
کن تج کل هده العمليات المستقلة › فان ال و0ناءةومم) يعتبر قد نجح ¢ وأما لو فشلت عملية واحدة من هذه العمليات 
> فیعتبر کل شئ کأن لم یکن » ویحدث عملیة )عمط اه۲ ۰ کی مال order-entery‏ في قاعدة البيانات Northwind‏ < 
حینما تقوم بادخال ملم للجدولین وازه†ەل ەلە - rds‏ فإما ان یتم حفظهما معا او حال الفشل يفشلا معاً. 
ها الخاصية Consistency‏ فهي تعني الابقاء على قاعدة البيانات في حالة ثابتة سو اء نجح Îآ— transaction‏ ام لا و لگی 
تحقق تكاملية البيانات integrity‏ هل فلابد أت يتسق ال transaction‏ مچ أي قيود مفروضة على ق أعمدة في الجدول 
¢ في مثال قاعدة البيانات لمiسطاإهN×‏ لايمكنك عمل أي شئ على الصفوف ی الجدول وانه)»5 ما0 من دون 
إجراءها على الصفوف المقابلة في الجدول وإملإ0 » لأن هذا يجعل البيانات في حالة غير ثابتة أرم)؟زيوcoمi.‏ 
ه الخاصية «0ناهاهء] وتبين ن لكل «0ناءهومهع) حدود مُعَّرفة » بما يعني عزل كل عملية عن الأخرى فلایتأتر عمل 
عملية بعمل العملية الأخرى » فلو هناك عملية تقراً بيانات الآن » لايُمكن بحال أن تتحصل عملية أخرى عن طبيعة هذه 
البيانات إلا بعد الانتهاء من العملية الأخرى أو قبلها أما في اثناءها فلا. 
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llخ|lصية :Durability‏ أي تعديل ناجم عن نجاح «٥ناءهومهع)‏ يتم حفظه بشكل دائم في النظام بغخض النظر عن حدوث 
أي شئ آخر› کما یتم تسجیل (logging)‏ هذه العمليات > ذا فأي خطا ينجم عنها یتم تدارکه إلى حالته الأصلية قبل هذا 
الخطأً » فبنهاية ال م0ناءوومه) يتم تسجيل الصف في ه1 «نا مومه لقاعدة البيانات » وفي حالة حدوث الخطأً ما 
في نظام قاعدة البيانات يتم استعادة قاأعدة البيانات من backup‏ ومن تم پمکننا استعادة ال transaction‏ المتحقق مسبقا 
عن طريق هذا ال ۽0[ وiransact10.‏ 
يتم فرض هذه الخصائص بصفة آلية على أي خادم قواعد بيانات . 


تصميم أ Transactions‏ 
أغلب العمل على ال يم0ناعهومهإ) مستوحى من أمثلة حقيقية متل المعاملات البنكية »> حجوزات الطيران حولات مالية ...إلخ › 
لهذا كان الغرض من عملية تصميم (معنءمل) ال «0ناءهءمهع) هو ابراز الخصائص الأساسية لهذه العمليات لتنقل هذه العمليات 
من الأنظمة اليدوية إلى الأنظمة الالكترونية بوضوح » وتضمن هذه العملية مايلي: 
هم مأهية قاعدة البيانات المستخدمة لهذا ال وم0ناcعtransa‏ 
ه الخصائص الو ظيفية لل و0ناهكمra{‏ 
transaction — ili e‏ 
6 دور المستخدمين 
TART‏ 
وهناك ثلاثة أنو | ‘transactions —| ja‏ 
أ - Retrieval transaction‏ وهو معني باسترجاع بيانات من الشاشة المعر وضة 
؟- Update transaction‏ يقوم بادخال سجلات جديدة او حذف قديمة أو التعديل فی سجلات مو جودة ف قاعدة البيانات 
Mixed transaction -۳‏ وهو خليط مابين النو عين السابقين 


Transaction آ—‎ تIلاح‎ 

في حالة عدم حدوث أي مشكلة » يتم تنفيذ ال «مناموومهع) بنجاح > وكما أسلفنا لابد من تمامية عمل ال م0نامهومه) حتى يقال 
عنه ناجح > يعتبر ال م0ناعهومهم) الغير مكتمل مجهضا لعاإهطه اذا لم يقم بالوظيفة بشكل تام حتى ولو قبل النهاية بقليل › 
ويعتبر ناجحا committed‏ اذا تم تنفبده بالكلية ¢ الشكل اللي ي وصح هذه الحالات٠‏ 


Transactions İl (Boundaries) jııعت‎ 


تساعدنا حدود ال «0ناموومهإ) على معرفة متى تبداً وتنتهي ال ءہەناcھsم Q1 Server tra‏ بمعرفة دوال وخواص ال ۸۴1 
وكذا جمل 1-S]‏ كما في التالي: 


: ه جمل 1-8@1: لتوصيف ال و٥1)ءهومهع) استخدم الجمل التالية‎ 
BEGIN TRANSACTION, COMMIT TRANSACTION, COMMIT WORK, ROLLBACK TRANSACTION, 
ROLLBACK WORK, SET IMPLICIT TRANSACTIONS 


وتستخدم هذه الجمل مع ءامذإءء 1-5Q1‏ كمثل تلك التي تثنفذ باستخدام [ووه التي تنفذ باستخدام محث الاوامر 4مھ con‏ 
prompt utitlity‏ . 
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دوال وخواص ۸۲1 : حيث تحتوي على ي۸1 58 مثل ۸50 ,28 DBC , ٥E‏ كما تحتوي على .NE†‏ 
SQLCIient namespace‏ يحوى هو الأخر دوال ووظائف تستخدہم لتو صیيف | transaction‏ 
يتم إدارة ال ومنامهومه) عن طريق أي من هذه الخواص بشرط أن تكون خاصية واحدة فقط وإلا سيحدث نتائج غير مرغوبة, 
على سبيل المثال لايُمكنك استخدام وظائف ۸۲1 058٤‏ لكي يبدا ال transaction‏ في حين أنك تستخدe T-SQL COMMIT‏ 
لكي تنهیه › فهذا لن يُخطر مُشغل SQ Server 0258٣‏ أن ال ہەناsacم tra‏ قد تم « لذا eعليك jÎ‏ تږتخد ODBC SQLEndTran‏ 
لكي تنهي ال cto‏ saہra).‏ 


ماهي جمل 1-5@1 المسموح بها في اأ Transaction؟‏ 
مسمو ح لكل استعمال كافة جمل T-SQL‏ المختلفة في التعامل مع ال s«ەناء2ومهع)‏ فيما عدا الجمل التالية: 
ALTER DATABASE, RECONFIGURE, BACKUP, RESTORE, CREATE DATABASE, UPDATE‏ 
STATISTICS ‘DROP DATABASE‏ 
كما لايمكنك استخدام الإجراء SP_ dboption‏ لتغيير أي خیارات في قاأعدة البيانات أو استخدام أي اجراءات مخزنة في تعدیل 
قاعدة البيانات الرئيسية master‏ 8ے ال tranaSCcCtiOons‏ الصريحة أو الضمنية. 


العمليات المحلية )Loca1 Transactions)‏ في LاSQ‏ 


تدعم كافة محرکات قو اعد البيانات بنية ذاتبة خأاصة لدعم ال transactions‏ “< وتسمی ال transactions‏ الى يتم قصر ها علی 
قأعدة بيانات وأحدة أو مصدر واحد بال transactions‏ المحلية ¢ ویمکن ان تو جد في أربعة ا کما چالتالی: 
Autocom mit "ransactions‏ يعتبر هذا النمط هو الرئيسي لإدارة ال ومناموومهع) داخل Q1 Server‏ فیتمٍ حفظ کل 
جملةً 1-8@Q]‏ عند الإكتمال بنجاح أو التراجع عنها في حالة حدوث أف اخطاء » و يظل هذا النمط افتراضياً مالم يتم 
التعديل على اي من أنواع گآ transactions‏ 
Explicit Transactions ®‏ وهو النمط الذي تتحکم فيه بشكل مباشر عند بداية أو نهاية ال «مناءهوءمهع) وكان هذا النمط 
یسمی فی الإصدار ۲۰۰۰ من 8Q1 Server‏ باسم user-defined transaction‏ › ویتم استخدام جمل ۲-۹@1 التالية في 
BEGIN TRANSACTION, COMMIT TRANSACTION, ROLLBACK TRANSACTION:ط¡aill ù‏ › ويعمل 
هذا النمط حال مده بقاءِ ا transaction‏ فعند الإنتهاء يعود الاتصال عد اخر اط [آ_ transaction‏ قبل استخدام هدا 
النمط المباشر. 
"ransactions‏ icitاmp]‏ يتم حفظ آي استعلام تم تنفیده في صورة 5(1 تقوم به حينما تتصل بقاعدة بيانات باستخدام 
MS SQL Server Management Studio‏ بطر يقة الية »> ويحدث هذا افتراضيا مادام الاتصال في aiږڊ AutoCommit‏ 
فإذا ما أردت أن تجعل هذه التغييرات ضمنية › فما عليك إلا أن تضع الاتصال بقاعدة البيانات في الوضع اإزامص! 
"ansaction‏ عن طریق الاستعلام: 


SET 
IMPLICIT _TRANSACTIONS ONIOFF 


وبعد وضعها في هذا النمط يقوم SQL Server‏ ببدء ال «مناعهومهإ) بطريقة ألية عندما يتم تنفید :أي من هذه الجمل: 
ALTER TABLE, CREATE, DELETE, DROP, FETCH, GRANT, INSERT, OPEN, REVOKE, SELECT,‏ 
TRUNCATE TABLE, UPDATE.‏ 
ویظJ‏ |Ûآ— transaction‏ فعالاً حتی د يتم التصر يح بllجlnۂ COMMIT‏ أو ROLLBACK‏ »فمثلاً عندما يتم تحديث سجل ما في 
قاعدة البيانات باستخدام الجملة [PÈ A1٤‏ فیقوم Q1 Server‏ بقفل قاعدة البيانات تلك الى ا يتم التصر یح باي من الجملتين 
السابقتين ويتم التراجع آليا عندما يقوم المستخدم بقطع الاتصال بقاعدة البيانات في حالة عدم استخدامك آيا من الجملتين 
السابقتين › ولهذا لايفضل استخدام هذا النمط مع قواعد البيانات ذات التزامنية العالية. 
Batch-Scoped Transactions ®‏ في هذا النمط يعمل ال وهنامهومهع) على اخر اج و عة من النتائج المتعددة فيما 
يعرف ب Multiple Active Result Sets‏ واختصاراً ب NARS‏ » فهذه الخاصية تمکن ا )ransacti0n‏ من تنفید ن أكثر 
من أمر نشط لأنها تحوي بيئة جيدة لدعم تنفيذ العمليات المتتابعة عن طریق کائنات ۸50.۴٤1‏ » فما يحدث هو أن أي 
تغيير يتم تركيزه على حزمة طط حتى تنتهي تماما » ويتم نسخ اعدادات التنفيذ الى البيئة الافتراضية › لذا هذا اأنمط 
یتم فقط حینما يتم تمكين 1۸858 وهناك أكثر من حزمة يتم تنفيذها معا »> وحتی لایحدث التباس فان ۸۸5 N"‏ تنفذ أكثر 
من حزمة وليس أكثر مڻ .transact101¬‏ 
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SQL qh (Distributed Transactions) العمليات llئjgn ع‎ 

على نقيض العمليات المحلية «٥ن)عدومصهع)‏ 1وءه!] التي تقتصر على مورد واحد او قاعدة بيانات واحدة » تشتمل العمليات 
الموزعة Distributed Transactions‏ على سرفرین أو أكثر ویطلق علیهم g resource managers‏ ينم التناغم بينهم عن طريق 
مکو ن خدمي یسمی transaction manager‏ أو transaction coordinator‏ < يستطيع SQL Server‏ أن يعمل كمدير للموارد 
للعمليات الموز عة مدعو ما — .Microsoft Distributed Transaction Coordenator (MS DTC) dûn transaction managers‏ 
Iآ transaction‏ ذو خادم قواعد البيانات الواحدو الذي يعمل علی قاعدتي بيانات أو أكثر Jal‏ ک— distributed transaction‏ 
وتتم إدارة هذه العملية الموز عة داخليا في إمرإمS؟S‏ اSQ.‏ 

يتم إدارة العمليات الموز عة علی مستو ی الأتطبيقات بنفس الالية الىئ یدار بها العمليات المحلية › > ففي نهاية تنفبد ن ال transaction‏ 
يتطلب منه تحديد الحالة مابين التمام أو التراخ ٠‏ »> في حالة التمام في العملية الموز عة يتم إدارتها بطريفة مختلفة حتى يتم تقليص 
الخطر الناجم عن أي مشاكل شبكية و هذه الطريقة د تسمی wo phase c٥1۸/1‏ وهی 

م رحلة التمهبد Prepare Phase‏ عندما يتسلم مدير العمليات طلب بالتمام » يقوم بارسال أمر تمهيد الى كافة مديري الموارد 
المستخدمة في العملية » وكل مدير مورد بدوره يعمل المطلوب التى تجعل العملية عإطهإu‏ > وأي بيانات مؤقتة استخدمت في 
تسجیل خطو ات هده العمليات يتم حفظها فى القرص > وبنهاية هده المرحلة يتم الرجوع بالنتيجة ناجحة او العملية فشلت لمدير 
العملية. 

مرحلة التسليم 0m mit Phase‏ »اذا تسلم مدير العملية رسالة نجاح عملية التمهيد من كافة مدير ي الموارد » يتم ارسال أمر 
العملية للتطيق › أما لو تم ارسال رسالة اخفاق من أي مدير للموارد فيتم على تراجع للعملية برمتها ويتم ارسال حالة فشل 
دليلك لكتابة أكواد عمليات فعالة 

هذه بعض الاقترحات من اجل كتابة أكواد للعمليات كى تعمل بكفاءة: 

ه لا تُجبر المستخدم على مدخلات أثناء العملية » اذا أردت ذلك عليك بملئ هذه المدخلات قبل بدء العملية اما لو تُطلب 
ذلك أثناء العملية فما عليك إلا عمل تراجع عن العملية )عوط 11ع ثم دع المستخد يضيف المدخلات اللازمة › ثم أعد 
تنفيذ العملية مرة اخرى › والسبب في ذلك أن هذه العمليات تتم في كسور من الثانية مما يعوقها بطئ المستخد في 
مدخلاته فينجم عنها اخطاء غير مرغوبة. 

ه لا تقم بفتح عملية أثناء معالجتها لبيانات » فالمفترض ان أية عملية لاتبداً قبل نهاية عملية التحليل التحضيري للبيانات. 

ه حافظ على كون العملية قصيرة بقدر المستطاع > اجعلها فقط بداية العملية ثم تنفيذ تعديل « ثم اصدار رسالة نجاح او 

هه حاول أن تستخدم أقل قدر من البيانات أثناء العملية » لأن هذا بدوره سيقلل عد الصفوف المقفولة مما يقلل من التضارب 
فيما بين العمليات. 


كيفية برمجة العمليات 
نستخدم الجمل التلاثة التالية لكي نتحكم في |آ transactions‏ في :SQL Server‏ 
:BEGIN "RANSACTION‏ وهي لتحديد بداية العملية. 
:0MM|IT TRANSACTION *‏ وهي لتحديد نجاح نهاية العملية > وتعطي اشارة لقاعدة البيانات لحفظ العمل. 


:R 011B ACK "RANSACTION‏ وهي لتوضيح أن العملية أخفقت كما وتعطي اشارة لقاعدة البيانات للتراجع الى 
الحالة التى سبق هده العملية. 


لاحظ انه لا یوجد جملة END "۴A NSA ٥110۸۲۸‏ لأن العملية تنتهي ضمنياً أو تصريحياً في حالة النجاح و الإخفاق. 
برمجة العمليات باستخدام Q1؟-1‏ 


سنقوم باستخدام الإجراءات المخزنة لنتدرب على برمجة العمليات باستخدام مثال غير حقيقي لتتعرف على الأساسيات وسنركز 
على طريقة عمل ال ومن) مهوم وما ستحتاجه بالفعل عندما تبر مجه باستخدام لغة ال .C#‏ 


C# 2010 and MSSQL Servef 2008 برمجة قواعد البيانات باستخدام‎ 


حسام كمال محمد 


كما وننوه على أن استخدامك لجمل "01184۸٣ , 00M M17‏ داخل الإجراء المُخزن يتطلب الحرص من كون العملية بالفعل 
قيد التشغيل من جراء استدعاءها من هذا الاجراء المُخزن › لا تشغل بالا بطريقة عمل المثال ولكن ينبغي الحرص. 
سنقوم الان بكتابة «ماءهومه]) لكي يضيف ويحذف عميل من قاعدة البيانات كمس ط٤إهN‏ في الجدول وإعمص میں٤‏ » هذا 


الجدول يحوي 1۲ موا »> منهم عمودان Custone/15‏ و 
يسمح بذلك » لذا سنستخدم كلا العمودين في ادخال البيانات 
نستعرض الزبائن مرتبين حسب ال 10. 


CompanyName‏ لايسمحان بالقيم الفار غة 11ں في حين الباقي 
¢ وسنستخدم العمود CustomerID‏ ى عملية ایجاد الصفوف عندما 


e‏ قم بفتح SQ1 Server Management studio‏ كما تعودت وقم بالاتصال بخادم قواعد البیانات. 
e‏ قم بتو سعة قواعد البيانات في التصفح الشجري حتى ترى قاعدة انبيlانlات Northwind‏ إن لم تكن ظاهرة بالفعل ثم قم 


بفتح نافدة استعلام جديدة .New Query‏ 


ه قم بانشاء اجراء مخزن ۲٥٥م‏ ۲۵۵٥ء‏ مستخدما الكود بالأسفل ثم اضغط ۴5 للتنفيذ: 


create procedure sp_ Trans_ Test 

@newcustid nchar(5), 

@newcompname nvarchar(40), 

@oldcustıid nchar(5) 

as 

declare @1nserr int 

declare @delerr int 

declare @maxerr 1nt 

set @maxerr = 0 

begın transaction 

-- Add a customer 

insert into customers (101ustomerID, companyname) 
values( @newcustid, @newcompname) 

-- Save error number returned from Insert statement 
set @1nserr = @ @error 

1f @1nserr > @maxerr 

set @maxerr = @1nserr 

-- Delete a customer 

delete from customers 

where 101ustomerlD = @oldcustid 

-- Save error number returned from Delete statement 
set @delerr = @ @error 

1f @delerr > @maxerr 

set @maxerr = @delerr 

-- Tf an error occurred, roll back 

1f @maxerr <> 0Û 

begin 

rollback 

print "Transaction rolled back! 

end 

else 

begin 

commit 

print "Transaction committed’ 

end 

print INSERT error number: + cast(@inserr as nvarchar(8)) 
print 'DELETE error number:' + cast( @delerr as nvarchar(8)) 
return @maxerr 
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ه لكي تقوم بتجربة الاجراء الذي أنشاته قم بكتابة الاستعلام التالي أسفل الاستعلام السابق » وقم بتظليله ثم اضغط 


٠ 


Execute‏ لتشغيل الاجراء: 


exec sp_ Trans_ Test 'a ', 'a', 'z 


لترى في نافذة النتائج رجوع النتائج بصفر كما بالشكل التالي: 


File Edit View Query Project Debug Tools Window Community Help 
9 ev ue | | ا‎ 5 | E 2 1 
: A1 BÛ | NORTHWIND.MDF - | ¥ Execute 3 E 1" E ES rT 


SES Suer LOMHosam GPF < *' 
Connect” AF 1 : rollback 


101 


print "Transaction rolled back" 


= 7 [local] (SQL Server 10.501617 - KSA-DEV-OO1" Hossam] 


end‏ ت 
ا E E‏ 
Ll System Databases beak‏ 
[O Database Snapshots E‏ 
AdventureWorks print 'Transaction committed'‏ 1 
E lJ aspnetdb eni‏ 
lJ CivilDefense_Applications print "INSERT error number:" + cast [(#inserr as nvarchar (8) j‏ @ 
NORTHWIND.MDF print "DELETE error number:' + cast [(Bdelerr as nvarchar (8) |‏ ۲ 
Reportseryer return Amaxerr‏ ۲ 
RepaortSerrer TempDE‏ ۲ 
EH CA Security‏ 
EH O Server Objects‏ 
i Replication‏ 


iA Management 
Eb) SL Server Agent [Agent XPs disabled] 


EH 


KSA-DEV-001\Hossam (57) | NORTHWIND.MDF | 00:00:00 | 0 rows 


ه في نافذة الاستعلام قم بإضافة الجملة التالية: 


= 

3 Messages 
{1 rows] affected] 
{O0 rows] affected) 


Transaction cormiüûtted 
IHSERT error number 20 


DELETE error number: 0 


Query executed successfully. | (local) OSD RTM]‏ ي 


Select * from Customers 


قم بتظليلها كما بالشكل واضغط م)ںءء×ع لترى العميل المسمى "و" قد أضيف للجدول : 


جد جد | س د | ل |8 ل | ت ھ ا[ لکا ا ی چ 


„7 SQLQuery1.sql - (...OO1\Hossam (57) x 
rw ۰ 
FPFrIint "Transaction conmitted " 8 
ena 
print "INSERT error number:'" + ca3zt (#inserr as nvarchar [8] ] 
print "DELETE error number:'" + cast [(g§dAelerr as nvarchar [38] ] 


TEEUrN HSmazxerr 


EڳxET‎ Sp Trans Test "a ', "ga 1" E 


SELE tE * fron Customers 


4 | II 


3] Results 


CustomerlD CompanyName Lortact Name Loantact Title re3 ity 

| : 2 اا ی‎ a i a a 

|2 ALK Alfreds Futterkiste Maria Anders Sales Representative Obere Str. 57 Berin 

3 AMNMATR ûna Trujillo Emparedadas ¥ helados Ana Trujillo ner ûw da. de la Lanstituciên ÃZZZÃZ  Mêico Û.F. 


1۰۲ 
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قم بإضافة راوع مستخدما القيمة "وه" لكل من dناcusءnew@‏ و عصnewcompna@‏ والقيمة "7" للمعامل 
csutid‏ 0 عن طريق الجملة : 
exec sp_ Trans_ Test 'aa ', 'aa', Zz '‏ 
ه حاول ان تستخدم جملة )ءم][مء كما بالسابق لترى أنه قد أضيف الزبون باسم "هه" فقط قم بتظليل جملة ءء[مء السابقة 
وتنفيذها لترى النتيجة. 
لشرح ماحدث فإننا قمنا بتعريف ثلاثة معاملات إدخال في الإجراء الممخزن ٠:‏ 
create procedure sp_ Trans_ Test‏ 
@newcustid nchar(5),‏ 
@newcompname nvarchar(40),‏ 
@oldcustid nchar(5)‏ 
as‏ 
declare @1nserr int‏ 
declare @delerr int‏ 
declare @maxerr 1nt‏ 
کے نستخدمها مع الإجراء الممُخزن حيث تعو د بعدد الأخطاء الحادثة جراء استخدام llجJa INSERT‏ ڪ .DELETE‏ 
قمنا بتحديد بداية العملية عن طريق الجملة BEGIN RA NSAC٣°110×‏ واتبعناھا بالجملتين 1NSER T1‏ و DELE 1۴٤‏ وبعد کل 
جملة يتم تخزين الر قم العائد ٠‏ 
begın transaction‏ 
Add a customer‏ -- 
insert into customers (customer1ld, companyname)‏ 
values( @newcust1d, @newconame)‏ 
Save error number returned from Insert statement‏ -- 
set @1nserr = @ @error‏ 
1f @1nserr > @maxerr‏ 
set @maxerr = @1nserr‏ 
Delete a customer‏ -- 
delete from customers‏ 
where customerid = @oldcustid‏ 
Save error number returned from Delete statement‏ -- 
set @delerr = @ @error‏ 
if @delerr > @maxerr‏ 
set @maxerr = @delerr‏ 


انه لمن المهم استدراك الأخطاء في إء۷إء؟ اQ؟‏ خاصة في أكواد العمليات » فلربما أثناء تنفيذك لأي جملة يحدث إخفاق › 
'صفر "''. 

بعد تنفيذ كل جملة _1اQ؟-1‏ بنجاح يتم اعادة ضبط الدالة ٠ @ @ ٤۸ R۸0۸‏ لذا اذا اردت أن تعيد قيمة الخطأ داخليا كما في حالتنا 
تلك » فقط قم بتخزين رقم الخطأ في معامل » قبل تنفيذ الجملة التي تليه لكي يُمكنك قراءتها فيما بعد. 

في حالة رجو ع الدالة 8۸۸0۸ @ @ بأية قيمة بخلاف الصفر › فهذا يعني ان ثمة خطأ ما قد حدث » وتحتاج الى التراجع عن 
العملية مرة اخرى ٠‏ قمنا ايضا بادراج الجملة "R1١١‏ لكي توضح ان العملية تمت بنجاح او تم التراجع عنها: 


-- Tf an error occurred, roll back 
1f @maxerr <> 0Û 

begin 

rollback 

print "Transaction rolled back! 
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end 

else 

begin 

commit 

print "Transaction committed’ 
end 


تستخدہم ۲-٩1‏ العديد من الكلمات المحفوظة بتنويعاتها معا ٤‏ المتال السابق استخدمنا فقط الجlnتيj ROLLBACK‏ و 
.COMMIT‏ 
قمنا با کک ام بعض الحيل ¢ أنتمكن من رؤية أرقام اطا الحادثة اننا العملية. 

print INSERT error number: + cast(@inserr as nvarchar(8)) 


print 'DELETE error number:' + cast( @delerr as nvarchar(8)) 
return @maxerr 


لنرى ماحدث عندما قمنا بتنفيذ الاجراء المخزن: 

قمنا بتشغيله مرتين › المرة الأولي لإضافة الزبون "" والمرة الثانية لإضافة الزبون "هه" » وقمنا باضافتهم على الرغم من 
عدم وجودهم الى الجملة م)م1مل » ولما يحدث اخفاق أو نجاح يحدث هذا بشكل موحد كوحدة واحدة » اذا لماذا حينما يحدث 
نجاح لعملية ]NSE§1‏ يتوقف عمل الجlnۀ DELETE‏ ؟ 

في نافذة النتائج التي رأينها في الشكل قبل السابق » لعلك لاحظت ان قيمة 0 = اوم إهم » والسبب في عدم الحذف على 
الرغم من عودة قيمة م)ء1ءل بالنجاح » أن الصف غير موجود أصلاً ليتم حذفه » وأما في حالة الاخفاق فإنه سيرى الصف 
السابق ليقوم بحذفه » في الحقيقة لا يعامل هذا كخطأً في ٠1-81‏ أما باقي ال ومون ءلايمكن حذفهم باستثناء مثالينا لأنهم 
يحوون فروع منهم وإملإه 14نطء » ذلك لايمكن حذفهم قبل حذف الفروع . 


مثال لتجربة ماذا يحدث عن اخفاق العملية الأولى:- 
في هذا المثال حاول ان تضيف زبون مضاف بالفعل › ثم تحذف الأخر › قم بإضافة الزبون "هح" وقم بحذف الزبون "هه" عن 
طريق تنفيذ الاجراء التالي: 


لترى النتيجة كما بالشكل: 


exec sp_ Trans_ Test 'a', 'a', 'aa' 


eڳxECZ‎ Sp Trans Test 'a ', "gag 1", 7 1 ٣ 
Select * fron Customers 
EXEC Sp Trans Test 'aB ', "aa !', "7 


gec sp TIrans_ 


| 
٤ 
2 
4 | ıı ۴ 
تا‎ 
i Messages 
Hag 2o27, Level 14, State 1, Procedure ap Trana Test, Line 12 || 
Violation of PFREIMERY EEY conatraint "PFE Customers" . Cannot insert duplicate key in object "dbo Customers 


The statement has been terminated. 


{1 rcowia) affected) 

Transaction rolled back 
IHSERT error number Zb2? 
DELETE error number :0 
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واما أمر الحذف فعاد برقم الخطأ 0 » ويعني هذا كله أن العملية الأولى أخفقت والثانية نجحت لكن قد تم التراجع عنهاء ويمكنك 
الذهاب الى الجدول لترى ان الزبون "مه" لم يتم حذفه. 

ولفهم ماحدث » فإننا قمنا بإاضافة مستخدم موجود بالفعل › و هذا ما ينع SQL Server‏ اذ أنه من غير المسموح إضافة نفس 
القيمة للجدول > وهو مانوهنا عنه في سرد مزايا مرإم؟S Q1‏ › الجملة التثانية الخاصة بحذف الزبون "وه" قد تم تنفيذها بالفعل 
> لكن نظراً لأن ناتج الخطأً × لا يساوي صفر كما رأيت » فتم التراجع عن عملية الحذف. 

مثال أخر على اخفاق العملية الثانية:- 

ق هذا المتال سنقوم بإضافة زبون جديد › تم نقوم بحذف زبون ڏو سجل فر عي ۲٥٥۲۵‏ انطع في الجدول Orders‏ › قم باضافة 
الزبون "ھھھ" ثم قم بحذف الزبون "۸1۴۸1" عن طر يق الاستعلام التالي: 


ليظهر لك الناتج كما بالشكل التالي: 


exec sp_ Trans_ Test 'aaa', 'aaa' , 'ALFKIT 


E — 


5QLQuery2.sql - [..OOI{Hossam (37) ` SQL Query. sql les. ..-001\ Hossam (54))* | ج‎ | 
print 'INSEET error numberc:" + caat (Binserr a3 nvarchar (8jj ood “dl 


return Admaxerr 


exec 3p Irans Test 'a', 'a', 'z' 

Select * from Customers 

exec 3p Irans Test 'aa "', 'aa', 'z' 

exec 3p Irans Test 'a", "a", 'aa' E 


exec sp Irans Test 'aaa', 'aaa' 'ALFEI' 


hari O 
print 'DELETE error number:" + cast (@&4&delerr as nvyarcchar (38) ) 


3 Messages 


[1 rows] affected) 


Hag 547, Level lû, State Û, Procedure sp Trans Test, Line 13 

rhe DELETE statement conflicted with the REFERENCE constraint "FE Orders Customers". The conflict occurred 
The statement has been terminated . 

Transaction rolled back 

INSERT error number: 

DELETE error number: 547 


ظهر ناتج الخطاً للجملة 0818۲۴ بالرقم 7 ٠‏ وتم التراجع عن العملية بنفس ١‏ لکیفھة اتی تر اجغت بها فی المثال السابق › 
على الرغم من نجاح العملية الأولي › برجو ع القيمة 0 للأخطاء > إلا ت 
عن العملية كما رايت »› وتستطيع التاكد من ذلك بالجملة 

Select * from Customers 
لترى ان الزبون "ههه" غير موجود.‎ 


مثال لإخفاق كلا العمليتين:- 
جرب إدخال زبون موجود بالفعل » وجرب حذف عنصر لايمكن حذفه ءقم بكتابة الاستعلام التالي: 
exec sp_ Trans_ Test 'a', 'a', 'ALFKT‏ 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


لترى النتيجة كما بالشكل: 


„ SQLQuery2.sql - [..OO1I\Hossam (57)" | SQLQue y1.sql - (...-OLAHossam (4) 
print "INSERT error number:' + cast (d&inszerr as nvyarchar [8) j 
print "DELETE error number:' + cast [(@#delerr as nvarchar (8; j] 
return #maxerr 


eExeT Sp Trans Test "a ", 


Select * from Customers 

exec 3p Trans Test 'aa '", 'aa ' 

exec 3p Trans Test 'a'"', 'a', 'aa' 

exec sp TIrans Test 'aaa', 'aaa' , '"'ALFRKI' 
sp Trans Test "a", 


3 Messages 


سم پس س 


Hag Z27, Level 14, State 1, Procedure sp Trans Test, Line l2 یر‎ 


r 
¬ 
r 


Violation of PRIMARY EEY conatraint "FE Customers" _ annot insert duplicate key in object "dko Customers" | 


The atatement haa keen terminated . 

Hag 5437, Level lû, State Û, Procedure sp Trans Test, Line 13 

Ihe ÛELETE atatement conflicted with the REFERENTE constraint "FE Urders Customers". The conflict occurred : 
The statement has been terminated. 

Transaction rolled kack 

IHSERET error number: boz? 

DELETE error number 254? 


كما ظهر فى نافذة النواتج » أنه تم التراجع عن العملية كلها > بسبب اخفاق كلا الجملتین 1 ]NS٤۸‏ و DE1 E1۴‏ بظھور أرقام 
الاخطاء 2627 للإضافة و 547 للحذف » وتلاحظ أن الرسالة هذه المرة هي: 


The statement has been terminated. 


كتابة أكواد للعمليات باستخدام Tئ۸AD0.NE‏ 

في هذا المتال سنقوم يعم ( برنامج مقابل للاجراء 1 أمخز 5 الذي کتبناه کی الأمثلة السابقة sp_Trans_ Test‏ باستخدام ال .C#‏ 
ه قم بإنشاء مشروع جديد في فيجول ستوديو من النو & TransTest 4w gs Windows Application‏ 
قم بتسمية املف sو¢.Form1 .Transaction.cs JÛ‏ 


ه قم بتغيير اسم الفورمة اذى .ADO.NET Transaction In C#‏ 
قم بإاضافة 3 sە×0ط‏ × وكذا وامطاه] 3 وزر واحد› لتصبح الفورمة كما بالشكل: 


E ADORET Tao RCE am ES) 


Ney Customer ID: 
RNevy Company IU: 


Uld Customer IU: 


:Transaction.cs JÛ using directive ةغlض|ڊ‎ مۃã§‎ e 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Server‏ حسام کمال محمد 


using System.Data.SqlClent; 
ه قم بإدخال الكود التالي في الحدث )عناء_1ہ٥٤اںuط للزر 1ہ٥)اںط بالضغط مرتين على الزر ليفتح لك الكود:‎ 


SqlConnection conn = new SqlConnection(@"data source = .;jintegrated security = true; 
database = Northwind.mdf 
J 


// INSERT statement 

string sqlins = @" 

insert into customers (customerid, companyname ) 
values(@newcustid, @newconame) "; 

// DELETE statement 

string sqldel = @" 

delete from customers 

where customerid = @oldcustid"; 

// open connection 

conn.Open(); 

SqlTransaction sqltrans = conn.BeginTransaction(); 

try 

{ 

// create insert command 

SqlCommand cmdins = conn.CreateCommand( ) ; 
cmdins.CommandText = sqlins; 

cmdins.Transaction = sqltrans; 
cmdins.Parameters.Add("@Qnewcustid", System.Data. SqlDbType.NVarChar, 5); 
cmdins.Parameters.Add("@newconame", 
System.Data.SqlDbType.NVarChar, 30); 

// create delete command 

SqlCommand cmddel = conn.CreateCommand( ) ; 
cmddel.CommandText = sqldel; 

cmddel.Transaction = sqltrans; 
cmddel.Parameters.Add("@Qoldcustid",System.Data.SqlDbType.NVarChar, 5); 
// add customer 

cmdins.Parameters[ "@newcustid" ].Value = textBox1.Text; 
cmdins.Parameters[ "@newconame”" ].Value = textBox2.Text; 
cmdins. ExecuteNonQuery () ; 

// delete customer 
cmddel.Parameters["Qoldcustid" ].Value = textBox3.Text; 
cmddel.ExecuteNonQuery () ; 

// commit transaction 

sqltrans.Commit(); 


// no exception, transaction committed, give message 
MessageBox.Show("Transaction committed"); 


catch (System.Data.SqlClient.SqlException ex) 

{ 

// roll back transaction 

sqltrans.Rollback(); 

MessageBox. Shou ( 

"Transaction rolled back\n" + ex.Message, "Rollback Transaction"); 


ُ 


catch (System.Exception ex) 


{ 


MessageBox. Show("System Error\n" + ex.Message, "Error"); 


} 
finally 


{ 


// close connection 
conn.Close(); 


ُ 


برمجة قواعد البيانات باستخدام 2008 C# 2010 and MSSQL Serve‏ حسام کمال محمد 


: قم بتشغيل البرنامج عن طريق الضغط على ۴5 ثم ادخل القيم التالية على الترتيب‎ ٠ 
تم اضغط علی الزر عاںءم×ع لکل‎ "a" ," aa", ""aaa بدلا من القيم‎ SQL Server Jف‎ لJعفن كما کنا‎ "", "bb", "bb" 
قيمة على حدا » واذا أردت أن تحذف أحدهم قم بادخاله في المربع الثالث لتحذفه › لتظهر لك رسالة مفادها نجاح‎ 
العملية.‎ 

لتوضيح ماحدث ٠‏ فإننا قمنا بفتح اتصال مع قاعدة البيانات › تم أنشأنا transaction‏ < مچ ملاحظة أننا لا يمكننا انشاء اكثر من 

nەransacti)‏ مع الاتصال الواحد قبل التراجع عنه أو نجاحه » ولن يعمل ال ومناعهومهع) قبل فتح الاتصال ;0ى عم 0. con”‏ › 

// create insert command 
SqlCommand cmdins = conn.CreateCommand(); 
cmdins.CommandT'ext = sqlins; 
cmdins. Transaction = sqltrans; 
cmdins.Parameters.Add(" @newcustid", SqlDbT'ype.NVarChar, 5); 
cmdıins.Parameters.Add(" @newconame", SqlDbT'ype.NVarChar, 30); 
// create delete command 
SqlCommand cmddel = conn.CreateCommand)O; 
cmddel.Command Text = sqldel; 
cmddel. Transaction = sqltrans; 
cmddel.Parameters.Add(" @oldcustıd'", SqlDbT'ype.NVarChar, 5); 

: ثم قمنا باسناد القيم المدخلة فى التكست بوكس إلى ما يناظرها من معاملات داخل الاستعلام‎ 
// add customer 
cmdins.Parameters['" @newcustid"]. Value = textBox1. Text; 
cmdins.Parameters['"' @newconame"]. Value = textBox2. Text; 
cmdins.ExecuteNonQueryÛ; 
// delete customer 
cmddel!l.Parameters['" @oldcustid"]. Value = textBox3. Text; 
cmddel.ExecuteNonQuery(); 
catch (System.Data.SqlClient.SqlException ex) 


/I/Roll back transaction 
sqltrans.RollbackO; 


1 


خاتمة الفصل 
فى هذا الفصل قمنا بتغطية أساسيات ال ك١‏ وء ه۲٠‏ وماهية خصائصة المختلفة مثل ۸٥12‏ . تعرفنا 
على العمليات الموزعة والمحلية . كيفية كتابة كود العمليات باستخدام 1-5۵1 ومن ثم تعرفنا على كيفية 
عمل ذلك عن طریق ۸050.٤۲‏ واستخدام 2010 C#‏ . لديك الآأن الأساسيات للإنطلاق في كتابة العمليات 
الخاصة بك وقتما تحتاج . والمزيد من المهارات سنتعلمها فى الفصول القادمة إن شاء اللّه. 


انتظروا الإصدار الثاني من الكتاب مكتملاً بباقي الفصول إن شاء الله 


